2022-05-23 06:37 AM
Hello everyone,
I'm using the STM32H7 and the new fully reworked ethernet driver along with the LWIP and FreeRTOS for sending and receiving the UDP packets.
The issue is first two packets get corrupted when sending. I don't send the UDP packet with zeroes in the payload, but the first sent packet is filled with zeroes.
I've tried placing a delay in case the Ethernet is not properly initialized but that didn't fix anything.
I suspect that the memory gets corrupted, but cannot prove anything.
Does anybody know what could be the potential issue here?
Thanks
Solved! Go to Solution.
2022-05-26 07:50 AM
Hello everyone,
Just an FYI,
I added the clean data cache for the packet buffer which is sent over the UDP right before sending
and that appears to have fixed the issue (for now, at least).
Now, the initial packets and all the others that are sent out are fine.
I think the issue was that the data was updated and placed in the cache and the same buffer wasn't updated in the SRAM which is accessed by the DMA which takes the old values and sends them instead of the new updated ones which haven't been written through to the SRAM.
Thorough testing will follow.
SCB_CleanDCache_by_Addr((uint32_t*)(((uint32_t)packetBuffer) & ~(uint32_t)0x1F), packetSize+32);
sendPacket(packetBuffer, packetSize);
2022-05-23 07:19 AM
Do you use static IP address or DHCP? Are you referring to DCHP requests or ARPs that the LwIP sends out?
2022-05-23 07:23 AM
Hi Pavel,
I am using DHCP.
I'm not referring to the DHCP or ARP requests.
I'm sending (broadcasting) a custom payload using the sockets API.
So, the UDP packet with a custom payload (39 bytes in length) is broadcasted
(sent to 255.255.255.255).
2022-05-23 07:26 AM
"first two packets get corrupted when sending"
How do you know they're corrupted on sending - rather than in the receiving ... ?
2022-05-23 07:34 AM
Hi Andrew,
Because I've seen that the data sent out by the Ethernet driver uses corrupt data for some reason.
Even though that memory location should have proper data.
I've checked for stack overflow but that is not the case.
When I create the packet buffer on the stack and then introduce a delay of 2 seconds
and then send, there are no faulty packets at the start.
Proper packets are sent out.
Without the delay, the two corrupt packets are sent.
Don't know why does the delay help.
2022-05-23 07:57 AM
Are you doing something like passing a pointer to a local (auto) variable - so that what you pointed to is no longer there by the time the driver actually comes to send it ... ?
2022-05-23 08:36 AM
Caching issue? There's been a good discussion of this here (https://community.st.com/s/question/0D53W00001Z9K9TSAV/maintaining-cpu-data-cache-coherence-for-dma-buffers).
2022-05-24 12:03 AM
The buffer is static and it is only changed there, so that shouldn't be an issue.
2022-05-24 12:04 AM
Also, the data is correct if the delay is applied.
2022-05-24 12:06 AM
Hi Bob,
I've tried changing the MPU settings but it didn't help.
I'll check the discussion.