diff options
author | Gregory Nutt <gnutt@nuttx.org> | 2015-01-01 12:28:46 -0600 |
---|---|---|
committer | Gregory Nutt <gnutt@nuttx.org> | 2015-01-01 12:28:46 -0600 |
commit | af25f1123d65420a9d05e43b6b0bc929d09150eb (patch) | |
tree | 5d0e3c18bd72fbd2aa679a38a9093983c1c55826 | |
parent | 2042a54f1d8925a9514d87e290f17018188ab404 (diff) | |
download | nuttx-af25f1123d65420a9d05e43b6b0bc929d09150eb.tar.gz nuttx-af25f1123d65420a9d05e43b6b0bc929d09150eb.tar.bz2 nuttx-af25f1123d65420a9d05e43b6b0bc929d09150eb.zip |
TM4C129X Ethernet: Add logic to get pre-programmed MAC address from user FLASH registers
-rw-r--r-- | nuttx/arch/arm/src/tiva/Kconfig | 15 | ||||
-rw-r--r-- | nuttx/arch/arm/src/tiva/lm3s_ethernet.c | 4 | ||||
-rw-r--r-- | nuttx/arch/arm/src/tiva/tiva_ethernet.h | 15 | ||||
-rw-r--r-- | nuttx/arch/arm/src/tiva/tm4c_ethernet.c | 9 | ||||
-rw-r--r-- | nuttx/configs/dk-tm4c129x/src/Makefile | 4 | ||||
-rw-r--r-- | nuttx/configs/dk-tm4c129x/src/tm4c_ethernet.c | 99 | ||||
-rw-r--r-- | nuttx/configs/eagle100/include/board.h | 15 | ||||
-rw-r--r-- | nuttx/configs/eagle100/src/up_ethernet.c | 3 | ||||
-rw-r--r-- | nuttx/configs/ekk-lm3s9b96/include/board.h | 15 | ||||
-rw-r--r-- | nuttx/configs/ekk-lm3s9b96/src/up_ethernet.c | 3 | ||||
-rw-r--r-- | nuttx/configs/lm3s6432-s2e/include/board.h | 15 | ||||
-rw-r--r-- | nuttx/configs/lm3s6432-s2e/src/up_ethernet.c | 3 | ||||
-rw-r--r-- | nuttx/configs/lm3s6965-ek/include/board.h | 15 | ||||
-rw-r--r-- | nuttx/configs/lm3s6965-ek/src/up_ethernet.c | 3 | ||||
-rw-r--r-- | nuttx/configs/lm3s8962-ek/include/board.h | 15 | ||||
-rw-r--r-- | nuttx/configs/lm3s8962-ek/src/up_ethernet.c | 3 |
16 files changed, 147 insertions, 89 deletions
diff --git a/nuttx/arch/arm/src/tiva/Kconfig b/nuttx/arch/arm/src/tiva/Kconfig index a26a0d25c..1e48c668f 100644 --- a/nuttx/arch/arm/src/tiva/Kconfig +++ b/nuttx/arch/arm/src/tiva/Kconfig @@ -655,13 +655,6 @@ config TIVA_ETHLEDS ---help--- Enable to use Ethernet LEDs on the board. -config TIVA_BOARDMAC - bool "Board MAC" - default n - ---help--- - If the board-specific logic can provide a MAC address (via - tiva_ethernetmac()), then this should be selected. - config TIVA_ETHHDUPLEX bool "Force Half Duplex" default n @@ -889,6 +882,14 @@ config TIVA_ETHERNET_REGDEBUG Enable very low-level register access debug. Depends on DEBUG. endmenu # Tiva Ethernet Configuration + +config TIVA_BOARDMAC + bool "Board MAC" + default n + ---help--- + If the board-specific logic can provide a MAC address (via + tiva_ethernetmac()), then this should be selected. + endif # TIVA_ETHERNET if TIVA_SSI diff --git a/nuttx/arch/arm/src/tiva/lm3s_ethernet.c b/nuttx/arch/arm/src/tiva/lm3s_ethernet.c index 22cb53d8a..899ceb2a8 100644 --- a/nuttx/arch/arm/src/tiva/lm3s_ethernet.c +++ b/nuttx/arch/arm/src/tiva/lm3s_ethernet.c @@ -1410,7 +1410,7 @@ static inline int tiva_ethinitialize(int intf) #endif priv->ld_dev.d_private = (void*)priv; /* Used to recover private state from dev */ - /* Create a watchdog for timing polling for and timing of transmisstions */ + /* Create a watchdog for timing polling for and timing of transmissions */ #if TIVA_NETHCONTROLLERS > 1 # error "A mechanism to associate base address an IRQ with an interface is needed" @@ -1422,7 +1422,7 @@ static inline int tiva_ethinitialize(int intf) /* If the board can provide us with a MAC address, get the address * from the board now. The MAC will not be applied until tiva_ifup() - * is caleld (and the MAC can be overwritten with a netdev ioctl call). + * is called (and the MAC can be overwritten with a netdev ioctl call). */ #ifdef CONFIG_TIVA_BOARDMAC diff --git a/nuttx/arch/arm/src/tiva/tiva_ethernet.h b/nuttx/arch/arm/src/tiva/tiva_ethernet.h index 660f46300..534d23437 100644 --- a/nuttx/arch/arm/src/tiva/tiva_ethernet.h +++ b/nuttx/arch/arm/src/tiva/tiva_ethernet.h @@ -98,6 +98,21 @@ extern "C" int tiva_ethinitialize(int intf); #endif +/**************************************************************************** + * Name: tiva_ethernetmac + * + * Description: + * For the Ethernet Eval Kits, the MAC address will be stored in the non- + * volatile USER0 and USER1 registers. If CONFIG_TIVA_BOARDMAC is defined, + * this function will obtain the MAC address from these registers. + * + ****************************************************************************/ + +#ifdef CONFIG_TIVA_BOARDMAC +struct ether_addr; +void tiva_ethernetmac(struct ether_addr *ethaddr); +#endif + #undef EXTERN #if defined(__cplusplus) } diff --git a/nuttx/arch/arm/src/tiva/tm4c_ethernet.c b/nuttx/arch/arm/src/tiva/tm4c_ethernet.c index 80524f6ea..74ae68bcd 100644 --- a/nuttx/arch/arm/src/tiva/tm4c_ethernet.c +++ b/nuttx/arch/arm/src/tiva/tm4c_ethernet.c @@ -3938,6 +3938,15 @@ int tiva_ethinitialize(int intf) priv->txpoll = wd_create(); /* Create periodic poll timer */ priv->txtimeout = wd_create(); /* Create TX timeout timer */ + /* If the board can provide us with a MAC address, get the address + * from the board now. The MAC will not be applied until tiva_ifup() + * is called (and the MAC can be overwritten with a netdev ioctl call). + */ + +#ifdef CONFIG_TIVA_BOARDMAC + tiva_ethernetmac(&priv->dev.d_mac); +#endif + /* Enable power and clocking to the Ethernet MAC * * - Enable Power: Applies power (only) to the EMAC peripheral. This is not diff --git a/nuttx/configs/dk-tm4c129x/src/Makefile b/nuttx/configs/dk-tm4c129x/src/Makefile index d3365f77b..99739fa76 100644 --- a/nuttx/configs/dk-tm4c129x/src/Makefile +++ b/nuttx/configs/dk-tm4c129x/src/Makefile @@ -51,6 +51,10 @@ ifeq ($(CONFIG_ARCH_BUTTONS),y) CSRCS += tm4c_buttons.c endif +ifeq ($(CONFIG_TIVA_ETHERNET),y) +CSRCS += tm4c_ethernet.c +endif + ifeq ($(CONFIG_NSH_ARCHINIT),y) CSRCS += tm4c_nsh.c endif diff --git a/nuttx/configs/dk-tm4c129x/src/tm4c_ethernet.c b/nuttx/configs/dk-tm4c129x/src/tm4c_ethernet.c new file mode 100644 index 000000000..9394a4522 --- /dev/null +++ b/nuttx/configs/dk-tm4c129x/src/tm4c_ethernet.c @@ -0,0 +1,99 @@ +/************************************************************************************ + * configs/dk-tm4c129x/src/tm4c_ethernet.c + * + * Copyright (C) 2015 Gregory Nutt. All rights reserved. + * Authors: Gregory Nutt <gnutt@nuttx.org> + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * 3. Neither the name NuttX nor the names of its contributors may be + * used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS + * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, + * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, + * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS + * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED + * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN + * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + * POSSIBILITY OF SUCH DAMAGE. + * + ************************************************************************************/ + +/************************************************************************************ + * Included Files + ************************************************************************************/ + +#include <nuttx/config.h> + +#include <stdint.h> +#include <debug.h> +#include <assert.h> + +#include <arch/board/board.h> +#include <net/ethernet.h> + +#include "up_arch.h" +#include "chip.h" +#include "chip/tiva_flash.h" +#include "tiva_ethernet.h" + +/************************************************************************************ + * Pre-processor Definitions + ************************************************************************************/ + +/************************************************************************************ + * Private Functions + ************************************************************************************/ + +/************************************************************************************ + * Public Functions + ************************************************************************************/ + +/************************************************************************************ + * Name: tiva_ethernetmac + * + * Description: + * For the Ethernet Eval Kits, the MAC address will be stored in the non-volatile + * USER0 and USER1 registers. If CONFIG_TIVA_BOARDMAC is defined, this function + * will obtain the MAC address from these registers. + * + ************************************************************************************/ + +#ifdef CONFIG_TIVA_BOARDMAC +void tiva_ethernetmac(struct ether_addr *ethaddr) +{ + uint32_t user0; + uint32_t user1; + + /* Get the current value of the user registers */ + + user0 = getreg32(TIVA_FLASH_USERREG0); + user1 = getreg32(TIVA_FLASH_USERREG1); + + nlldbg("user: %06x:%06x\n", user1 & 0x00ffffff, user0 & 0x00ffffff); + DEBUGASSERT(user0 != 0xffffffff && user1 != 0xffffffff); + + /* Re-format that MAC address the way that uIP expects to see it */ + + ethaddr->ether_addr_octet[0] = ((user0 >> 0) & 0xff); + ethaddr->ether_addr_octet[1] = ((user0 >> 8) & 0xff); + ethaddr->ether_addr_octet[2] = ((user0 >> 16) & 0xff); + ethaddr->ether_addr_octet[3] = ((user1 >> 0) & 0xff); + ethaddr->ether_addr_octet[4] = ((user1 >> 8) & 0xff); + ethaddr->ether_addr_octet[5] = ((user1 >> 16) & 0xff); +} +#endif diff --git a/nuttx/configs/eagle100/include/board.h b/nuttx/configs/eagle100/include/board.h index 9b9f52007..f1b11bb3b 100644 --- a/nuttx/configs/eagle100/include/board.h +++ b/nuttx/configs/eagle100/include/board.h @@ -123,20 +123,5 @@ void tiva_boardinitialize(void); -/************************************************************************************ - * Name: tiva_ethernetmac - * - * Description: - * For the Ethernet Eval Kits, the MAC address will be stored in the non-volatile - * USER0 and USER1 registers. If CONFIG_TIVA_BOARDMAC is defined, this function - * will obtain the MAC address from these registers. - * - ************************************************************************************/ - -#ifdef CONFIG_TIVA_BOARDMAC -struct ether_addr; -void tiva_ethernetmac(struct ether_addr *ethaddr); -#endif - #endif /* __ASSEMBLY__ */ #endif /* __ARCH_BOARD_BOARD_H */ diff --git a/nuttx/configs/eagle100/src/up_ethernet.c b/nuttx/configs/eagle100/src/up_ethernet.c index 1b619ed97..47ba597f5 100644 --- a/nuttx/configs/eagle100/src/up_ethernet.c +++ b/nuttx/configs/eagle100/src/up_ethernet.c @@ -49,9 +49,10 @@ #include "up_arch.h" #include "chip.h" +#include "tiva_ethernet.h" /************************************************************************************ - * Definitions + * Pre-processor Definitions ************************************************************************************/ /************************************************************************************ diff --git a/nuttx/configs/ekk-lm3s9b96/include/board.h b/nuttx/configs/ekk-lm3s9b96/include/board.h index 755e74b50..2a93d45d1 100644 --- a/nuttx/configs/ekk-lm3s9b96/include/board.h +++ b/nuttx/configs/ekk-lm3s9b96/include/board.h @@ -124,20 +124,5 @@ void tiva_boardinitialize(void); -/************************************************************************************ - * Name: tiva_ethernetmac - * - * Description: - * For the Ethernet Eval Kits, the MAC address will be stored in the non-volatile - * USER0 and USER1 registers. If CONFIG_TIVA_BOARDMAC is defined, this function - * will obtain the MAC address from these registers. - * - ************************************************************************************/ - -#ifdef CONFIG_TIVA_BOARDMAC -struct ether_addr; -void tiva_ethernetmac(struct ether_addr *ethaddr); -#endif - #endif /* __ASSEMBLY__ */ #endif /* __ARCH_BOARD_BOARD_H */ diff --git a/nuttx/configs/ekk-lm3s9b96/src/up_ethernet.c b/nuttx/configs/ekk-lm3s9b96/src/up_ethernet.c index e62fc1520..26e3630a1 100644 --- a/nuttx/configs/ekk-lm3s9b96/src/up_ethernet.c +++ b/nuttx/configs/ekk-lm3s9b96/src/up_ethernet.c @@ -50,9 +50,10 @@ #include "up_arch.h" #include "chip.h" +#include "tiva_ethernet.h" /************************************************************************************ - * Definitions + * Pre-processor Definitions ************************************************************************************/ /************************************************************************************ diff --git a/nuttx/configs/lm3s6432-s2e/include/board.h b/nuttx/configs/lm3s6432-s2e/include/board.h index af6144c23..bedf9c86c 100644 --- a/nuttx/configs/lm3s6432-s2e/include/board.h +++ b/nuttx/configs/lm3s6432-s2e/include/board.h @@ -125,20 +125,5 @@ void tiva_boardinitialize(void); -/************************************************************************************ - * Name: tiva_ethernetmac - * - * Description: - * For the MDL-S2E Reference Design, the MAC address will be stored in the - * non-volatile USER0 and USER1 registers. If CONFIG_TIVA_BOARDMAC is defined, - * this function will obtain the MAC address from these registers. - * - ************************************************************************************/ - -#ifdef CONFIG_TIVA_BOARDMAC -struct ether_addr; -void tiva_ethernetmac(struct ether_addr *ethaddr); -#endif - #endif /* __ASSEMBLY__ */ #endif /* __ARCH_BOARD_BOARD_H */ diff --git a/nuttx/configs/lm3s6432-s2e/src/up_ethernet.c b/nuttx/configs/lm3s6432-s2e/src/up_ethernet.c index 7bffdb3ca..19ee2bbc1 100644 --- a/nuttx/configs/lm3s6432-s2e/src/up_ethernet.c +++ b/nuttx/configs/lm3s6432-s2e/src/up_ethernet.c @@ -49,9 +49,10 @@ #include "up_arch.h" #include "chip.h" +#include "tiva_ethernet.h" /************************************************************************************ - * Definitions + * Pre-processor oDefinitions ************************************************************************************/ /************************************************************************************ diff --git a/nuttx/configs/lm3s6965-ek/include/board.h b/nuttx/configs/lm3s6965-ek/include/board.h index fdbc0dd10..96ddd0136 100644 --- a/nuttx/configs/lm3s6965-ek/include/board.h +++ b/nuttx/configs/lm3s6965-ek/include/board.h @@ -123,20 +123,5 @@ void tiva_boardinitialize(void); -/************************************************************************************ - * Name: tiva_ethernetmac - * - * Description: - * For the Ethernet Eval Kits, the MAC address will be stored in the non-volatile - * USER0 and USER1 registers. If CONFIG_TIVA_BOARDMAC is defined, this function - * will obtain the MAC address from these registers. - * - ************************************************************************************/ - -#ifdef CONFIG_TIVA_BOARDMAC -struct ether_addr; -void tiva_ethernetmac(struct ether_addr *ethaddr); -#endif - #endif /* __ASSEMBLY__ */ #endif /* __ARCH_BOARD_BOARD_H */ diff --git a/nuttx/configs/lm3s6965-ek/src/up_ethernet.c b/nuttx/configs/lm3s6965-ek/src/up_ethernet.c index 4ae9ef0e9..6a7e0133f 100644 --- a/nuttx/configs/lm3s6965-ek/src/up_ethernet.c +++ b/nuttx/configs/lm3s6965-ek/src/up_ethernet.c @@ -49,9 +49,10 @@ #include "up_arch.h" #include "chip.h" +#include "tiva_ethernet.h" /************************************************************************************ - * Definitions + * Pre-processor Definitions ************************************************************************************/ /************************************************************************************ diff --git a/nuttx/configs/lm3s8962-ek/include/board.h b/nuttx/configs/lm3s8962-ek/include/board.h index 180e44dd3..8a1384d91 100644 --- a/nuttx/configs/lm3s8962-ek/include/board.h +++ b/nuttx/configs/lm3s8962-ek/include/board.h @@ -123,20 +123,5 @@ void tiva_boardinitialize(void); -/************************************************************************************ - * Name: tiva_ethernetmac - * - * Description: - * For the Ethernet Eval Kits, the MAC address will be stored in the non-volatile - * USER0 and USER1 registers. If CONFIG_TIVA_BOARDMAC is defined, this function - * will obtain the MAC address from these registers. - * - ************************************************************************************/ - -#ifdef CONFIG_TIVA_BOARDMAC -struct ether_addr; -void tiva_ethernetmac(struct ether_addr *ethaddr); -#endif - #endif /* __ASSEMBLY__ */ #endif /* __ARCH_BOARD_BOARD_H */ diff --git a/nuttx/configs/lm3s8962-ek/src/up_ethernet.c b/nuttx/configs/lm3s8962-ek/src/up_ethernet.c index bc20ea0f1..620231330 100644 --- a/nuttx/configs/lm3s8962-ek/src/up_ethernet.c +++ b/nuttx/configs/lm3s8962-ek/src/up_ethernet.c @@ -49,9 +49,10 @@ #include "up_arch.h" #include "chip.h" +#include "tiva_ethernet.h" /************************************************************************************ - * Definitions + * Pre-processor Definitions ************************************************************************************/ /************************************************************************************ |