I do love this chip - add Ethernet without dictating choice of microcontroller. Opens up the low pin count / cost micros to Ethernet. Big plus.
But… I’m struggling with the code that comes with it. I keep on fixing things, each time I ask myself, surely I’m not the only one!
So, Where did I get the code from? - The W5500 product page:
Links to this code here:
https://github.com/Wiznet/ioLibrary_Driver/tree/master[details=Summary]
As way of example – it the first ‘issue’ I came across…
“The webserver will not serve out binary files - such as images”
There seems to be a problem in httpServer.c
The function :
Essentially, it reads information from the file system and passes out data as part of the HTTP response (body). It uses “web_content” - a table of files previously registered with reg_httpServer_WebContent.
uint16_t read_userReg_webContent(uint16_t content_num, uint8_t * buf, uint32_t offset, uint16_t size)
{
uint16_t ret = 0;
uint8_t * ptr;
if(content_num > total_content_cnt) return 0;
ptr = web_content[content_num].content;
if(offset) ptr += offset;
strncpy((char *)buf, (char *)ptr, size);
*(buf+size) = 0; // Insert '/0' for indicates the 'End of String' (null terminated)
ret = strlen((void *)buf);
return ret;
}
The problem seems to be here… This statement aborts the copy if the .content buffer contains ‘\0’. Binary files have lots of these!
strncpy((char *)buf, (char *)ptr, size);
This line inserts a ‘\0’ char into the stream when reading a binary file outch
*(buf+size) = 0;
Once patched with this:
uint16_t read_userReg_webContent(uint16_t content_num, uint8_t * buf, uint32_t offset, uint16_t size)
{
uint16_t ret = 0;
uint8_t * ptr;
if(content_num > total_content_cnt) return 0;
ptr = web_content[content_num].content;
if(offset) ptr += offset;
memcpy (buf, ptr, size); // Do it properly.. *face palm*
return size; // this is a guess
}
Hey presto, images come through…
Rather worried, I pressed on and carried on fixing / patching to the point where my page loads 4/5 times when I hit the refresh button. Works better on Chrome than IE. The cause of this is not so easy to find. Now I’m left having to digest long logic analyser SPI trace streams to start to find this one. Not something I really want to do…
So, before I do this, I thought I’d ask other members - why is it just me who is having these kinds of problems?? Have I gone to the wrong party? Can someone tell me where I’m supposed to be?? I’m not having a good time here…
Repository digging. There seems to different revisions of files used in different project… I’ve got very confused…
Just take httpServer.c I’m using for example:
ioLibrary_Driver/httpServer.c at master · Wiznet/ioLibrary_Driver · GitHub [link only]
Seems to be a different version from (committed on Mar 9)
WIZ550S2E/httpServer.c at master · Wiznet/WIZ550S2E · GitHub [link only]
or from (committed 23 days ago)
WIZ550web/httpServer.c at master · Wiznet/WIZ550web · GitHub [link only]
That’s just main branch – is the party in a dev branch? I just don’t know anymore…
Clarification welcome…
On an additional note, I tried the mbed example. For me it just kept on getting stuck in polling loops buried in the http server code. This occurs when dealing with rapid page refreshes / ajax traffic. (Continuously polling status register not a good idea in event driven systems, especially when you poll for a state that will never occurs!)
As the mbed code is a bit more involved, after a few patches / fixes - I though id use the ioLibrary_Driver for a simpler solution. Now I’m here…
Note: Please keep this post to ioLibrary_Driver - I have abandoned mbed for now…
Thanks.