diff options
Diffstat (limited to 'libnet/inc/net.h')
-rw-r--r-- | libnet/inc/net.h | 46 |
1 files changed, 39 insertions, 7 deletions
diff --git a/libnet/inc/net.h b/libnet/inc/net.h index 5dd4ee1..6884690 100644 --- a/libnet/inc/net.h +++ b/libnet/inc/net.h @@ -6,6 +6,7 @@ #include <dns.h> #include <http.h> #include <ip.h> +#include <print.h> #include <socket.h> #include <sys.h> @@ -18,10 +19,32 @@ #define ip(a, b, c, d) \ ((((a)&0xff) << 24) | (((b)&0xff) << 16) | (((c)&0xff) << 8) | (((d)&0xff) << 0)) +#define NET_TIMEOUT 500 +#define NET_NO_TIMEOUT 0 + +static inline int net_data_available(struct socket *socket) +{ + return (socket && socket->packets && socket->packets->head && socket->packets->head->data && + ((struct socket_data *)socket->packets->head->data)->length > 0); +} + #define net_open(type) (void *)sys1(SYS_NET_OPEN, (int)(type)) -#define net_connect(socket, ip_addr, dst_port) \ - (int)sys3(SYS_NET_CONNECT, (int)(socket), (int)(ip_addr), (int)(dst_port)) #define net_send(socket, data, len) (void)sys3(SYS_NET_SEND, (int)(socket), (int)(data), (int)(len)) + +static inline int net_connect(struct socket *socket, u32 ip_addr, u16 dst_port, u32 timeout) +{ + if (!socket || !ip_addr || !dst_port) + return 0; + sys3(SYS_NET_CONNECT, (int)(socket), (int)(ip_addr), (int)(dst_port)); + int time = time(); + while (socket->state != S_CONNECTED) { + if (socket->state == S_FAILED || (timeout && time() - time >= timeout)) + return 0; + yield(); + } + return 1; +} + static inline int net_close(struct socket *socket) { int res = 0; @@ -29,12 +52,21 @@ static inline int net_close(struct socket *socket) ; return res; } -static inline int net_receive(struct socket *socket, void *buf, u32 len) + +static inline int net_receive(struct socket *socket, void *buf, u32 len, u32 timeout) { - int res = 0; - while (!(res = (int)sys3(SYS_NET_RECEIVE, (int)(socket), (int)(buf), (int)(len)))) - ; - return res; + if (!socket || !buf || !len) + return 0; + + int time = time(); + while (!net_data_available(socket)) { + if (socket->state == S_FAILED || (timeout && time() - time >= timeout)) + return 0; + yield(); + } + + // TODO: Only return once all segments are received? + return (int)sys3(SYS_NET_RECEIVE, (int)(socket), (int)(buf), (int)(len)); } #endif |