Skip to content

Infineon/nonrtos-lwip-mbedtls

master
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Code

Latest commit

 

Git stats

Files

Permalink
Failed to load latest commit information.
Type
Name
Latest commit message
Commit time
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Non-RTOS lwip mbedtls

This repo comprises core components needed for non-rtos connectivity support. The library bundles lwIP TCP/IP stack, mbed TLS for security, connectivity utilities and configuration files.

Features and functionality

This library provides the configuration files for lwIP network stack and mbedTLS security stack. It also includes following libraries as dependees in the ModusToolbox™ manifest system. Using ModusToolbox™ manifest system the dependees are automatically pulled when an application uses this library in ModusToolbox™ environment.

  • lwIP: A Lightweight open-source TCP/IP stack, version: 2.1.2. See the lwIP web site for details.

    Note: Using this library in a project will cause lwIP to be downloaded on your computer. It is your responsibility to understand and accept the lwIP license.

  • lwIP network interface integration library: This library is an integration layer that links lwIP network stack with underlying Wi-Fi Host Driver(WHD) and Ethernet driver. See lwIP network interface integration library for details.

  • mbed TLS: An open-source, portable, easy-to-use, readable and flexible SSL library that has cryptographic capabilities, version: 3.4.0. See the mbed TLS web site for details.

    Note: Using this library in a project will cause mbed TLS to be downloaded on your computer. It is your responsibility to understand and accept the mbed TLS license and regional use restrictions (including abiding by all applicable export control laws).

  • Connectivity utilities: The connectivity utilities library is a collection of general purpose middleware utilities. See the Connectivity utilities repository for details.

  • Predefined configuration files: For lwIP, and mbed TLS for typical embedded IoT use cases. See Quick Start section for details.

Supported platforms

This library and its features are supported on the following platforms:

Quick start

A set of pre-defined configuration files have been bundled with this library for lwIP, and mbed TLS. These files are located in the configs folder.

You should do the following:

  1. Copy lwipopts.h, and mbedtls_user_config.h files from the configs directory to the top-level code example directory in the project.

  2. Configure the MBEDTLS_USER_CONFIG_FILE C macro to mbedtls_user_config.h in the Makefile to provide the user configuration to the mbed TLS library. The Makefile entry should look like as follows:

    DEFINES+=MBEDTLS_USER_CONFIG_FILE='"mbedtls_user_config.h"'
    
  3. If your application uses automatic private IP addressing (Auto IP), enable LWIP_AUTOIP and LWIP_DHCP_AUTOIP_COOP in lwipopts.h like as follows:

    #define AUTOIP 1
    #define LWIP_DHCP_AUTOIP_COOP 1
    
  4. Add the following to COMPONENTS in the code example project's Makefile: LWIP, and MBEDTLS.

    For example:

    COMPONENTS=LWIP MBEDTLS
    
  5. To configure the Ethernet on XMC4700/XMC4800 Relax Kit and XMC4500 Relax Kit, open design.modus file and do the following configuration settings in the ModusToolbox™ Device Configurator.

    • Switch to the "System" tab.
    • Select "Clock Control Unit->"Ethernet Clock".
      Note: The minimum acceptable Ethernet clock frequency is 50 MHz.
    • For XMC4700 device, default Ethernet Clock frequency is 72 MHz.
    • For XMC4500 device, default Ethernet Clock frequency is 36 MHz. Follow below steps to configure Ethernet Clock frequency.
      • Select "Clock Sources"->"System PLL". Set Desired Frequency (MHZ) to 120MHz.
      • Select "Clock Control Unit"->"System Clock". Set Divider to 1.
      • Select "Clock Control Unit"->"Ethernet Clock". Set Divider to 2. This will configure Ethernet clock frequency to 60 MHz.
    • Switch to the "Peripherals" tab.
    • Select Communication->"Ethernet (ETH)" for XMC4700 device.
    • In "Ethernet (ETH) - Personality" tab, select "ETH_MAC_MW-1.0" from the drop-down.
    • In "Ethernet (ETH) - Parameters" pane, configure interface type "PHY Interconnect" to "RMII" from the drop-down.
    • Configure PHY driver "PHY Device" to "KSZ8081RNB" from the drop-down.
    • Enable/Disable "Autonegotiation" (default is enable).
    • Configure "PHY speed" (10/100 Mbits/sec) based on the device.
      Note: "PHY speed" and "PHY Duplex Mode" options are visible only when the "Autonegotiation" is disabled.
    • Configure "Mac Address".
    • Enable "Promiscuous mode" (default is disable).
    • Enable "Accept Broadcast Frames" (default is enable).
    • Configure static IP or use DHCP (default is use DHCP).
    • To configure pin connections, refer "Ethernet" section of XMC4700/XMC4800 Relax Kit User Manual or XMC4500 Relax Kit User Manual. Below is an example for pin configurations.
      • For ETH_CRS_DV pin, Select "CYBSP_ETH_CRS" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "input" from the drop-down.
        • Configure "Input mode" to "Tristate" from the drop-down.
      • For ETH_RX_ER pin, Select "CYBSP_ETH_RXER" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "input" from the drop-down.
        • Configure "Input mode" to "Tristate" from the drop-down.
      • For ETH_RXD0 pin, Select "CYBSP_ETH_RXD0" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "input" from the drop-down.
        • Configure "Input mode" to "Tristate" from the drop-down.
      • For ETH_RXD1 pin, Select "CYBSP_ETH_RXD1" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "input" from the drop-down.
        • Configure "Input mode" to "Tristate" from the drop-down.
      • For ETH_TX_EN pin, Select "CYBSP_ETH_TXEN" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "input/ouptut" from the drop-down.
        • Configure "Driver Strength" to "Strong Driver Sharp Edge" from the drop-down.
      • For ETH_TXD0 pin, Select "CYBSP_ETH_TXD0" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "input/ouptut" from the drop-down.
        • Configure "Driver Strength" to "Strong Driver Sharp Edge" from the drop-down.
      • For ETH_TXD1 pin, Select "CYBSP_ETH_TXD1" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "input/ouptut" from the drop-down.
        • Configure "Driver Strength" to "Strong Driver Sharp Edge" from the drop-down.
      • For ETH_CLKRMII pin, Select "CYBSP_ETH_CLK" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "input" from the drop-down.
        • Configure "Input mode" to "Tristate" from the drop-down.
      • For ETH_MDC pin, Select "CYBSP_ETH_MDC" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "input/ouptut" from the drop-down.
        • Configure "Driver Strength" to "Strong Driver Sharp Edge" from the drop-down.
      • For ETH_MDO pin, Select "CYBSP_ETH_MDIO" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "Hardware Controlled" from the drop-down.
        • Configure "Driver Strength" to "Strong Driver Sharp Edge" from the drop-down.
      • For ETH_MDI pin, Select "CYBSP_ETH_MDIO" from the drop-down.
        • Click on "Go to signal" of selected pin,
        • Configure "Pin Direction" to "Hardware Controlled" from the drop-down.
        • Configure "Driver Strength" to "Strong Driver Sharp Edge" from the drop-down.
    • Save the configuration to generate the necessary code.
  6. XMC4000 devices supports both Rx Polling and Interrupt mode for handling receive data. By default Interrupt mode is enabled. To enable Polling mode select the option "Poll For Received Data" in the device configurator.

  7. If Rx Polling mode is enabled along with Non-RTOS mode in device configurator, the user has to call the below function periodically to receive data.

    ETH_LWIP_Poll();
    
  8. All the log messages are disabled by default. Do the following to enable log messages:

    1. Add the ENABLE_CONNECTIVITY_MIDDLEWARE_LOGS macro to the DEFINES in the code example's Makefile to enable logs for lwIP network interface integration library. The Makefile entry should look like as follows:

      DEFINES+=ENABLE_CONNECTIVITY_MIDDLEWARE_LOGS
      
    2. Call the cy_log_init() function provided by the cy-log module. cy-log is part of the connectivity-utilities library. See connectivity-utilities library API documentation for cy-log details.

  9. Secure applications requires more stack and heap memory. It is recommended to configure 3K or higher for stack and 56K or higher for heap.

    1. The stack and heap size can be updated directly in the linker file. The reference linker file for ARM tool chain is available in template_linker/XMC4800/TOOLCHAIN_ARM/linker.sct

    Note : The stack size can be modified using the LDFLAGS for toolchain GCC_ARM. The Makefile entry should look like as follows:

    LDFLAGS +=-Wl,--defsym,stack_size=3072
    

lwIP, and mbed TLS libraries contain reference and test applications. To ensure that these applications do not conflict with the code examples, a .cyignore file is also included with this library.

Note : CY_RTOS_AWARE shall not be defined in the build configuration. If CY_RTOS_AWARE is added in the defines, system will switch to RTOS mode.

Code Snippets

In the Non-RTOS mode, RTOS features like threads, mutex etc are not available. The reference code examples for Non-RTOS mode are available in Code Snippets

Additional information

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published