Hello,
I am a bit confused as to which API I should use for communication with PC running Win7. Seems like the TCP api is more event driven whereas the BSD is the classic implementation. Does the TCP is implemented on top of the BSD sockets or they are not related at all. Do they both require RTX running The Microcontroller will run as a TCP server.
Many thanks Nick
Thanks, indeed I meant whether BSD utilizes the TCP API (as they can also be used for DATAGRAMS. Seems like the TCP API allows a bit more control over the communication.
What do you mean by, "TCP API" ?
TCP is a network protocol - not an API.
Your TCP/IP Stack is a piece of software that will provide an API to use it - for details, you will have to study its documentation...
I mean the TCP and BSD Network components as of here: www.keil.com/.../using_network_sockets.html My original question was if one wanted to create an application which uses TCP to communicate, which of these two APIs (tcp/bsd) would pick to use. Which library offers more flexibility/control and which programming paradigm is better. For example, from what I read the TCP is more event driven. Maybe BSD is using the TCP component and it is good enough. I am trying to read and understand the documentation but I am new in the embedded world (and ARM/Keil) and I have quickly understood that coding is different to what I am used to.
All networking stacks are supporting TCP/IP and UDP/IP since the huge majority of all networking is using these two protocols for the transmitted data.
Berkley sockets is basically a design concept (and not the only one) with function calls suitable for writing networking software. So it can be seen as a "portability" solution for how a program will interface with the networking stack. And you can most definitely use both TCP or UDP depending on your needs.
If you are going to use TCP or UDP depends on what problem you want to solve. UDP doesn't have connections and data can be lost. But is much faster, since it never hangs waiting for any acknowledge.
I wonder if you're asking about the specific TCPnet implementation supplied by Keil.
Historically, the TCPnet libraries only supported what I think you are referring to as the TCP API. It can be used both with or without the RTX.
It provides quite a lot of control, but my personal opinion is that it's not very 'programmer friendly'. For example, the TCP related functions are not re-entrant and the documentation states "All TCPnet-related functionality should be collected in a single networking task". Of course, limitations like these can be overcome, but it certainly took me a considerable time to feel I was controlling it reliably.
The BSD socket interface was added to TCPnet relatively recently. It attempts to implement a standard Berkeley Socket communication interface. But the documentation states that "These APIs are not a complete implementation of the BSD API". It sits on top of (and makes use of) the original networking facilities.
I have not used this BSD support, but as far as I am aware they are re-entrant, require the RTX and, being more standard, are more likely to be easier for someone to learn how to use them.
For any new project, it would probably be sensible to seriously consider using the BSD API.
Thanks IB Shy, this was the answer I was looking for.
The interesting thing about the Berkeley socket interface is that almost all networking sample code on the net is for (or almost for) this API. And the majority of all network programming books describes this API and shows sample code for (or almost for) this API.
This is because the Berkeley sockets is the foundation for what later evolved into POSIX Sockets.
Note that the choice of API has nothing to do with the type of the remote host.