<div dir="ltr"><div><div>Hi Joel,<br><br></div>I will look into that. I managed to get everything to compile now but I now have issues with the aforementioned sections and the <br></div><div>code crashes in the low leven initialization function for LwIP. I stepped through the code and compared the addresses of the descriptors for the<br></div><div>working code using FreeRTOS and the code using RTEMS. The descriptor entries for FreeRTOS seem to contain the SRAM 3 addresses while<br></div><div>the descriptors in RTEMS only contains zeroes.. Does anyone have an idea what might cause this? I attached pictures of the debug output as well..<br><br></div><div>Kind Regards<br></div><div>Robin.<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, 28 Jan 2021 at 15:11, Joel Sherrill <<a href="mailto:joel@rtems.org">joel@rtems.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div>Specific addresses shouldn't be in the shared linkcmds.base.</div><div><br></div><div>You could define new macro names like the other memory types and addresses and add those to the generic linkcmds. Then the linkcmds.base would generically know those sections and your BSP could set the right macros to place it.</div><div><br></div><div>One thought is to add linkcmds.lwip which have those special sections (if they are common in LWIP -- not driver specific), and then have the BSP define the right things and then include linkcmds.lwip and linkcmds.base. That way BSPs which want to potentially use lwip could include the lwip linkcmds fragment and get the sections.</div><div><br></div><div>But if those section names are driver specific, this isn't a good organization and we will have to think more.</div><div><br></div><div>Hope that makes sense.</div><div><br></div><div>--joel</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jan 28, 2021 at 7:37 AM Robin Müller <<a href="mailto:robin.mueller.m@gmail.com" target="_blank">robin.mueller.m@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div><div>Some clarification: The linker script used for RTEMS is of course the default RTEMS linker script, the FreeRTOS example used the linker file taken from the STM32CubeH7 repository.<br><br></div>Kind Regards<br></div>Robin Müller<br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, 28 Jan 2021 at 14:35, Robin Müller <<a href="mailto:robin.mueller.m@gmail.com" target="_blank">robin.mueller.m@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div><div><div><div>Hi,<br><br></div>I am trying to get LwIP working on the STM32H7 because it has a low RAM usage (at least that's what I heard). We already did this for FreeRTOS, but we used the LwIP Raw API to not be bound specifically to the OS. I am now trying to adapt LwIP to RTEMS , but I'm not really a LwIP expert and most did copy & paste up until now.<br><br></div>So far, transferring the code has worked, but there are some specific sections in the code used for our FreeRTOS example which put the ethernet DMA descriptors in specific sections:<br><br>
ETH_DMADescTypeDef DMARxDscrTab[ETH_RX_DESC_CNT] __attribute__((section(".RxDecripSection"))); /* Ethernet Rx DMA Descriptors */<br>ETH_DMADescTypeDef DMATxDscrTab[ETH_TX_DESC_CNT] __attribute__((section(".TxDecripSection")));   /* Ethernet Tx DMA Descriptors */<br>uint8_t Rx_Buff[ETH_RX_DESC_CNT][ETH_RX_BUFFER_SIZE] __attribute__((section(".RxArraySection"))); /* Ethernet Receive Buffers */<br><br>/* For RTEMS can we put this in the text section? */<br>//ETH_DMADescTypeDef DMARxDscrTab[ETH_RX_DESC_CNT]; /* Ethernet Rx DMA Descriptors */<br>//ETH_DMADescTypeDef DMATxDscrTab[ETH_TX_DESC_CNT];   /* Ethernet Tx DMA Descriptors */<br>//uint8_t Rx_Buff[ETH_RX_DESC_CNT][ETH_RX_BUFFER_SIZE]; /* Ethernet Receive Buffers */

<br><br></div>I got an "section `.unexpected_sections' will not fit in region<br>       *   `UNEXPECTED_SECTIONS'" error because of this. I checked the linker script used, which was taken from the STM32CubeH7 repository and found this LwIP specific section:<br><br>  .lwip_sec (NOLOAD) : {<br>    . = ABSOLUTE(0x30040000);<br>    *(.RxDecripSection) <br>    <br>    . = ABSOLUTE(0x30040060);<br>    *(.TxDecripSection)<br>    <br>    . = ABSOLUTE(0x30040200);<br>    *(.RxArraySection) <br>  } >RAM_D2 AT> FLASH<br><br></div>So the descriptors are placed at RAM_D2 (or SRAM_3 in RTEMS). I've placed the following<br>section in linkcmds.base now:<br><br>    .lwip_sec (NOLOAD) : ALIGN_WITH_INPUT {<br>        . = ABSOLUTE(0x30040000);<br>        *(.RxDecripSection) <br>    <br>        . = ABSOLUTE(0x30040060);<br>        *(.TxDecripSection)<br>    <br>        . = ABSOLUTE(0x30040200);<br>       *(.RxArraySection) <br>  } >SRAM_3 AT> REGION_TEXT_LOAD<div><div><br></div><div>Are any STM32 or LwIP experts here that see a problem with this adaption? I still need to do some other stuff to integrate LwIP properly so I haven't tested it yet. Are there any other thinks I need to take into account for making LwIP work with RTEMS?<br><br></div><div>Kind Regards<br></div><div>Robin<br></div></div></div>
</blockquote></div>
_______________________________________________<br>
users mailing list<br>
<a href="mailto:users@rtems.org" target="_blank">users@rtems.org</a><br>
<a href="http://lists.rtems.org/mailman/listinfo/users" rel="noreferrer" target="_blank">http://lists.rtems.org/mailman/listinfo/users</a></blockquote></div></div>
</blockquote></div>