overview.rst 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. .. _overview:
  2. Overview
  3. ========
  4. .. _overview_intro:
  5. Introduction
  6. ------------
  7. .. note::
  8. This is Nuclei N100 SDK which is modified based on **Nuclei SDK 0.5.0** to support Nuclei 100 series CPU.
  9. If you are looking for Nuclei SDK for Nuclei **200/300/600/900/1000** CPU, please refer to https://doc.nucleisys.com/nuclei_sdk
  10. Please use **Nuclei Studio >= 2025.02** with this Nuclei N100 SDK.
  11. The **Nuclei N100 Software Development Kit (SDK)** is an open-source software platform to
  12. speed up the software development of SoCs based on Nuclei Processor 100 series Cores.
  13. This Nuclei N100 SDK is built based on the **modified** |NMSIS| for N100 and also the APIs that provided by Nuclei N100 SDK which mainly for on-board
  14. peripherals access such as UART etc.
  15. Nuclei N100 SDK provides a good start base for embedded developers which will help them simplify
  16. software development and improve time-to-market through well-designed software framework.
  17. .. note::
  18. To get a pdf version of this documentation, please click `Nuclei N100 SDK Document`_
  19. .. _overview_design_arch:
  20. Design and Architecture
  21. -----------------------
  22. The Nuclei N100 SDK general design and architecture are shown in the block diagram as below.
  23. .. _figure_overview_1:
  24. .. figure:: /asserts/images/nuclei_sdk_diagram.png
  25. :width: 80 %
  26. :align: center
  27. :alt: Nuclei N100 SDK Design and Architecture Diagram
  28. Nuclei N100 SDK Design and Architecture Diagram
  29. As :ref:`figure_overview_1` shown, The Nuclei N100 SDK provides the following features:
  30. * Nuclei Core API service is built on top of **modified** |NMSIS|, so silicon vendors of Nuclei processors can easily
  31. port their SoCs to Nuclei N100 SDK, and quickly evaluate software on their SoC.
  32. * Mainly support :ref:`design_soc_evalsoc`
  33. * Provided realtime operation system service via :ref:`design_rtos_freertos`, :ref:`design_rtos_ucosii` and
  34. :ref:`design_rtos_rtthread`
  35. * Provided bare-metal service for embedded system software beginners and resource-limited use-cases.
  36. * Applications are logically separated into three parts:
  37. - **General applications for Nuclei 100 series Processors**: In the Nuclei N100 SDK software code, the applications provided
  38. are all general applications which can run on all Nuclei Processors, with basic UART service to provide ``printf`` function.
  39. - **Nuclei Eval SoC applications**: These applications are not included in the Nuclei N100 SDK software code, and it is
  40. *maintained separately*, which will use resource from Nuclei Eval SoC and its evaluation boards to develop applications, which will
  41. not be compatible with different boards.
  42. .. _overview_getstarted:
  43. Get Started
  44. -----------
  45. Please refer to :ref:`quickstart` to get started to take a try with Nuclei N100 SDK.
  46. .. _overview_contribute:
  47. Contributing
  48. ------------
  49. Contributing to Nuclei N100 SDK is welcomed, if you have any issue or pull request
  50. want to open, you can take a look at :ref:`contribute` section.
  51. .. _overview_copyright:
  52. Copyright
  53. ---------
  54. Copyright (c) 2019 - Present, Nuclei System Technology. All rights reserved.
  55. Redistribution and use in source and binary forms, with or without modification,
  56. are permitted provided that the following conditions are met:
  57. 1. Redistributions of source code must retain the above copyright notice, this
  58. list of conditions and the following disclaimer.
  59. 2. Redistributions in binary form must reproduce the above copyright notice,
  60. this list of conditions and the following disclaimer in the documentation
  61. and/or other materials provided with the distribution.
  62. 3. Neither the name of the Nuclei System Technology., nor the names of its contributors
  63. may be used to endorse or promote products derived from this software without
  64. specific prior written permission.
  65. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
  66. ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  67. WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  68. DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
  69. ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  70. (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  71. LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
  72. ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  73. (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  74. SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. NY THEORY OF
  75. LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
  76. OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  77. ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  78. .. _overview_license:
  79. License
  80. -------
  81. Nuclei N100 SDK is an opensource project licensed by :ref:`Apache License 2.0 <license>`.
  82. .. _Nuclei N100 SDK Document: https://doc.nucleisys.com/nuclei_n100_sdk/nuclei_n100sdk.pdf