RTEMS Logo

RTEMS 4.10.0 On-Line Library


Directory Structure c/src/ Directory

PREV UP NEXT Bookshelf RTEMS Development Environment Guide

2.1.1: c/src/ Directory

  • Directory Structure c/src/lib/libbsp BSP Directory
  • As mentioned previously, this directory is logically the root for the RTEMS components which are CPU model or board dependent. The following is a list of the subdirectories in this directory and a description of each.

    ${RTEMS_ROOT}/c/src/aclocal/
    This directory contains the custom M4 macros which are available to the various GNU autoconf configure.ac scripts throughout this portion of the RTEMS source tree. GNU autoconf interprets configure.ac files to produce the configure files used to tailor RTEMS build for a particular host and target environment. The contents of this directory will not be discussed further in this document.
    ${RTEMS_ROOT}/c/src/ada/
    This directory contains the Ada95 language bindings to the RTEMS Classic API.
    ${RTEMS_ROOT}/c/src/ada-tests/
    This directory contains the test suite for the Ada language bindings to the Classic API.
    ${RTEMS_ROOT}/c/src/automake/
    This directory contains files which are "Makefile fragments." They are included as required by the various Makefile.am files throughout this portion of the RTEMS source tree.
    ${RTEMS_ROOT}/c/src/lib/
    This directory contains the directories libbsp/ and libcpu/ which contain the source code for the Board Support Packages (BSPs) and CPU Model specific source code for RTEMS.

    The libbsp/ is organized based upon the CPU family and boards BSPs. The contents of libbsp/ are discussed briefly in Directory Structure c/src/lib/libbsp BSP Directory and presented in detail in the RTEMS BSP and Device Driver Development Guide.

    The libcpu/ directory is also organized by CPU family with further divisions based upon CPU model and features that are shared across CPU models such as caching and DMA.

    ${RTEMS_ROOT}/c/src/libchip/
    This directory contains device drivers for various peripheral chips which are designed to be CPU and board dependent. This directory contains a variety of drivers for serial devices, network interface controllers, shared memory and real-time clocks.
    ${RTEMS_ROOT}/c/src/librtems++/
    This directory contains C++ classes which map to the RTEMS Classic API.
    ${RTEMS_ROOT}/c/src/make/
    This directory is used to generate the bulk of the supporting rules files which are installed as part of the Application Makefiles. This file contains settings for various Makefile variables to tailor them to the particular CPU model and BSP configured.
    ${RTEMS_ROOT}/c/src/nfsclient/
    This directory contains a Network File System (NFS) client for RTEMS. With this file system, a user's application can access files on a remote computer.
    ${RTEMS_ROOT}/c/src/optman/
    This directory contains stubs for the RTEMS Classic API Managers which are considered optional and whose use may be explicitly forbidden by an application. All of the directive implementations in this Optional Managers return E_NOTCONFIGURED.
    ${RTEMS_ROOT}/c/src/support/
    This directory exists solely to generate the RTEMS version string which includes the RTEMS version, CPU architecture, CPU model, and BSP name.
    ${RTEMS_ROOT}/c/src/wrapup/
    This directory is responsible for taking the individual libraries and objects built in each of the components in the RTEMS source tree and bundling them together to form the single RTEMS library librtemsbsp.a. This library contains all BSP and CPU model specific software.


    PREV UP NEXT Bookshelf RTEMS Development Environment Guide

    Copyright © 1988-2008 OAR Corporation