wolfio.h 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822
  1. /* io.h
  2. *
  3. * Copyright (C) 2006-2023 wolfSSL Inc.
  4. *
  5. * This file is part of wolfSSL.
  6. *
  7. * wolfSSL is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * wolfSSL is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
  20. */
  21. /*!
  22. \file wolfssl/wolfio.h
  23. */
  24. #ifndef WOLFSSL_IO_H
  25. #define WOLFSSL_IO_H
  26. #include <wolfssl/ssl.h>
  27. #ifdef __cplusplus
  28. extern "C" {
  29. #endif
  30. /* Micrium uses NetSock I/O callbacks in wolfio.c */
  31. #if !defined(WOLFSSL_USER_IO)
  32. /* OCSP and CRL_IO require HTTP client */
  33. #if defined(HAVE_OCSP) || defined(HAVE_CRL_IO)
  34. #ifndef HAVE_HTTP_CLIENT
  35. #define HAVE_HTTP_CLIENT
  36. #endif
  37. #endif
  38. #endif
  39. #if !defined(WOLFSSL_USER_IO)
  40. /* Micrium uses NetSock I/O callbacks in wolfio.c */
  41. #if !defined(USE_WOLFSSL_IO) && !defined(MICRIUM) && \
  42. !defined(WOLFSSL_CONTIKI) && !defined(WOLFSSL_NO_SOCK)
  43. #define USE_WOLFSSL_IO
  44. #endif
  45. #endif
  46. #if defined(USE_WOLFSSL_IO) || defined(HAVE_HTTP_CLIENT)
  47. #ifdef HAVE_LIBZ
  48. #include "zlib.h"
  49. #endif
  50. #ifndef USE_WINDOWS_API
  51. #if defined(WOLFSSL_LWIP) && !defined(WOLFSSL_APACHE_MYNEWT)
  52. /* lwIP needs to be configured to use sockets API in this mode */
  53. /* LWIP_SOCKET 1 in lwip/opt.h or in build */
  54. #include "lwip/sockets.h"
  55. #ifndef LWIP_PROVIDE_ERRNO
  56. #include <errno.h>
  57. #define LWIP_PROVIDE_ERRNO 1
  58. #endif
  59. #elif defined(ARDUINO)
  60. /* TODO Add specific boards */
  61. #elif defined(FREESCALE_MQX)
  62. #include <posix.h>
  63. #include <rtcs.h>
  64. #elif defined(FREESCALE_KSDK_MQX)
  65. #include <rtcs.h>
  66. #elif (defined(WOLFSSL_MDK_ARM) || defined(WOLFSSL_KEIL_TCP_NET))
  67. #include "rl_net.h"
  68. #include "errno.h"
  69. #elif defined(WOLFSSL_CMSIS_RTOS)
  70. #include "cmsis_os.h"
  71. #elif defined(WOLFSSL_CMSIS_RTOSv2)
  72. #include "cmsis_os2.h"
  73. #elif defined(WOLFSSL_TIRTOS)
  74. #include <sys/socket.h>
  75. #elif defined(FREERTOS_TCP)
  76. #include "FreeRTOS_Sockets.h"
  77. #elif defined(WOLFSSL_IAR_ARM)
  78. /* nothing */
  79. #elif defined(HAVE_NETX_BSD)
  80. #ifdef NETX_DUO
  81. #include "nxd_bsd.h"
  82. #else
  83. #include "nx_bsd.h"
  84. #endif
  85. #elif defined(WOLFSSL_VXWORKS)
  86. #include <sockLib.h>
  87. #include <errno.h>
  88. #elif defined(WOLFSSL_NUCLEUS_1_2)
  89. #include <externs.h>
  90. #include <errno.h>
  91. #elif defined(WOLFSSL_LINUXKM)
  92. /* the requisite linux/net.h is included in wc_port.h, with incompatible warnings masked out. */
  93. #elif defined(WOLFSSL_ATMEL)
  94. #include "socket/include/socket.h"
  95. #elif defined(INTIME_RTOS)
  96. #undef MIN
  97. #undef MAX
  98. #include <rt.h>
  99. #include <sys/types.h>
  100. #include <sys/socket.h>
  101. #include <netdb.h>
  102. #include <netinet/in.h>
  103. #include <io.h>
  104. /* <sys/socket.h> defines these, to avoid conflict, do undef */
  105. #undef SOCKADDR
  106. #undef SOCKADDR_IN
  107. #elif defined(WOLFSSL_PRCONNECT_PRO)
  108. #include <prconnect_pro/prconnect_pro.h>
  109. #include <sys/types.h>
  110. #include <errno.h>
  111. #include <unistd.h>
  112. #include <fcntl.h>
  113. #elif defined(WOLFSSL_SGX)
  114. #include <errno.h>
  115. #elif defined(WOLFSSL_APACHE_MYNEWT) && !defined(WOLFSSL_LWIP)
  116. #include <mn_socket/mn_socket.h>
  117. #elif defined(WOLFSSL_DEOS)
  118. #include <socketapi.h>
  119. #include <lwip-socket.h>
  120. #include <errno.h>
  121. #elif defined(WOLFSSL_ZEPHYR)
  122. #include <version.h>
  123. #if KERNEL_VERSION_NUMBER >= 0x30100
  124. #include <zephyr/net/socket.h>
  125. #ifdef CONFIG_POSIX_API
  126. #include <zephyr/posix/sys/socket.h>
  127. #endif
  128. #else
  129. #include <net/socket.h>
  130. #ifdef CONFIG_POSIX_API
  131. #include <posix/sys/socket.h>
  132. #endif
  133. #endif
  134. #elif defined(MICROCHIP_PIC32)
  135. #include <sys/errno.h>
  136. #elif defined(HAVE_NETX)
  137. #include "nx_api.h"
  138. #include "errno.h"
  139. #elif defined(FUSION_RTOS)
  140. #include <sys/fcltypes.h>
  141. #include <fclerrno.h>
  142. #include <fclfcntl.h>
  143. #elif !defined(WOLFSSL_NO_SOCK)
  144. #include <sys/types.h>
  145. #include <errno.h>
  146. #ifndef EBSNET
  147. #include <unistd.h>
  148. #endif
  149. #include <fcntl.h>
  150. #define XFCNTL(fd, flag, block) fcntl((fd), (flag), (block))
  151. #if defined(HAVE_RTP_SYS)
  152. #include <socket.h>
  153. #elif defined(EBSNET)
  154. #include "rtipapi.h" /* errno */
  155. #include "socket.h"
  156. #elif defined(NETOS)
  157. #include <sockapi.h>
  158. #elif !defined(DEVKITPRO) && !defined(WOLFSSL_PICOTCP) \
  159. && !defined(WOLFSSL_CONTIKI) && !defined(WOLFSSL_WICED) \
  160. && !defined(WOLFSSL_GNRC) && !defined(WOLFSSL_RIOT_OS)
  161. #include <sys/socket.h>
  162. #include <arpa/inet.h>
  163. #include <netinet/in.h>
  164. #ifdef __PPU
  165. #include <netex/errno.h>
  166. #else
  167. #endif
  168. #endif
  169. #endif
  170. #if defined(WOLFSSL_RENESAS_RA6M3G) || defined(WOLFSSL_RENESAS_RA6M3) ||\
  171. defined(WOLFSSL_RENESAS_RA6M4) || \
  172. defined(WOLFSSL_RENESAS_RZN2L)
  173. /* Uses FREERTOS_TCP */
  174. #include <errno.h>
  175. #endif
  176. #if defined(WOLFSSL_EMBOS)
  177. #include <errno.h>
  178. #endif
  179. #endif /* USE_WINDOWS_API */
  180. #ifdef __sun
  181. #include <sys/filio.h>
  182. #endif
  183. #ifdef USE_WINDOWS_API
  184. /* no epipe yet */
  185. #ifndef WSAEPIPE
  186. #define WSAEPIPE -12345
  187. #endif
  188. #define SOCKET_EWOULDBLOCK WSAEWOULDBLOCK
  189. #define SOCKET_EAGAIN WSAETIMEDOUT
  190. #define SOCKET_ECONNRESET WSAECONNRESET
  191. #define SOCKET_EINTR WSAEINTR
  192. #define SOCKET_EPIPE WSAEPIPE
  193. #define SOCKET_ECONNREFUSED WSAENOTCONN
  194. #define SOCKET_ECONNABORTED WSAECONNABORTED
  195. #elif defined(__PPU)
  196. #define SOCKET_EWOULDBLOCK SYS_NET_EWOULDBLOCK
  197. #define SOCKET_EAGAIN SYS_NET_EAGAIN
  198. #define SOCKET_ECONNRESET SYS_NET_ECONNRESET
  199. #define SOCKET_EINTR SYS_NET_EINTR
  200. #define SOCKET_EPIPE SYS_NET_EPIPE
  201. #define SOCKET_ECONNREFUSED SYS_NET_ECONNREFUSED
  202. #define SOCKET_ECONNABORTED SYS_NET_ECONNABORTED
  203. #elif defined(FREESCALE_MQX) || defined(FREESCALE_KSDK_MQX)
  204. #if MQX_USE_IO_OLD
  205. /* RTCS old I/O doesn't have an EWOULDBLOCK */
  206. #define SOCKET_EWOULDBLOCK EAGAIN
  207. #define SOCKET_EAGAIN EAGAIN
  208. #define SOCKET_ECONNRESET RTCSERR_TCP_CONN_RESET
  209. #define SOCKET_EINTR EINTR
  210. #define SOCKET_EPIPE EPIPE
  211. #define SOCKET_ECONNREFUSED RTCSERR_TCP_CONN_REFUSED
  212. #define SOCKET_ECONNABORTED RTCSERR_TCP_CONN_ABORTED
  213. #else
  214. #define SOCKET_EWOULDBLOCK NIO_EWOULDBLOCK
  215. #define SOCKET_EAGAIN NIO_EAGAIN
  216. #define SOCKET_ECONNRESET NIO_ECONNRESET
  217. #define SOCKET_EINTR NIO_EINTR
  218. #define SOCKET_EPIPE NIO_EPIPE
  219. #define SOCKET_ECONNREFUSED NIO_ECONNREFUSED
  220. #define SOCKET_ECONNABORTED NIO_ECONNABORTED
  221. #endif
  222. #elif defined(WOLFSSL_MDK_ARM)|| defined(WOLFSSL_KEIL_TCP_NET)
  223. #define SOCKET_EWOULDBLOCK BSD_ERROR_WOULDBLOCK
  224. #define SOCKET_EAGAIN BSD_ERROR_LOCKED
  225. #define SOCKET_ECONNRESET BSD_ERROR_CLOSED
  226. #define SOCKET_EINTR BSD_ERROR
  227. #define SOCKET_EPIPE BSD_ERROR
  228. #define SOCKET_ECONNREFUSED BSD_ERROR
  229. #define SOCKET_ECONNABORTED BSD_ERROR
  230. #elif defined(WOLFSSL_PICOTCP)
  231. #define SOCKET_EWOULDBLOCK PICO_ERR_EAGAIN
  232. #define SOCKET_EAGAIN PICO_ERR_EAGAIN
  233. #define SOCKET_ECONNRESET PICO_ERR_ECONNRESET
  234. #define SOCKET_EINTR PICO_ERR_EINTR
  235. #define SOCKET_EPIPE PICO_ERR_EIO
  236. #define SOCKET_ECONNREFUSED PICO_ERR_ECONNREFUSED
  237. #define SOCKET_ECONNABORTED PICO_ERR_ESHUTDOWN
  238. #elif defined(FREERTOS_TCP)
  239. #define SOCKET_EWOULDBLOCK FREERTOS_EWOULDBLOCK
  240. #define SOCKET_EAGAIN FREERTOS_EWOULDBLOCK
  241. #define SOCKET_ECONNRESET FREERTOS_SOCKET_ERROR
  242. #define SOCKET_EINTR FREERTOS_SOCKET_ERROR
  243. #define SOCKET_EPIPE FREERTOS_SOCKET_ERROR
  244. #define SOCKET_ECONNREFUSED FREERTOS_SOCKET_ERROR
  245. #define SOCKET_ECONNABORTED FREERTOS_SOCKET_ERROR
  246. #elif defined(WOLFSSL_NUCLEUS_1_2)
  247. #define SOCKET_EWOULDBLOCK NU_WOULD_BLOCK
  248. #define SOCKET_EAGAIN NU_WOULD_BLOCK
  249. #define SOCKET_ECONNRESET NU_NOT_CONNECTED
  250. #define SOCKET_EINTR NU_NOT_CONNECTED
  251. #define SOCKET_EPIPE NU_NOT_CONNECTED
  252. #define SOCKET_ECONNREFUSED NU_CONNECTION_REFUSED
  253. #define SOCKET_ECONNABORTED NU_NOT_CONNECTED
  254. #elif defined(WOLFSSL_DEOS)
  255. /* `sockaddr_storage` is not defined in DEOS. This workaround will
  256. * work for IPV4, but not IPV6
  257. */
  258. #define sockaddr_storage sockaddr_in
  259. #define SOCKET_EWOULDBLOCK EAGAIN
  260. #define SOCKET_EAGAIN EAGAIN
  261. #define SOCKET_ECONNRESET EINTR
  262. #define SOCKET_EINTR EINTR
  263. #define SOCKET_EPIPE EPIPE
  264. #define SOCKET_ECONNREFUSED SOCKET_ERROR
  265. #define SOCKET_ECONNABORTED SOCKET_ERROR
  266. #elif defined(HAVE_NETX)
  267. #define SOCKET_EWOULDBLOCK NX_NOT_CONNECTED
  268. #define SOCKET_EAGAIN NX_NOT_CONNECTED
  269. #define SOCKET_ECONNRESET NX_NOT_CONNECTED
  270. #define SOCKET_EINTR NX_NOT_CONNECTED
  271. #define SOCKET_EPIPE NX_NOT_CONNECTED
  272. #define SOCKET_ECONNREFUSED NX_NOT_CONNECTED
  273. #define SOCKET_ECONNABORTED NX_NOT_CONNECTED
  274. #elif defined(FUSION_RTOS)
  275. #define SOCKET_EWOULDBLOCK FCL_EWOULDBLOCK
  276. #define SOCKET_EAGAIN FCL_EAGAIN
  277. #define SOCKET_ECONNRESET FNS_ECONNRESET
  278. #define SOCKET_EINTR FCL_EINTR
  279. #define SOCKET_EPIPE FCL_EPIPE
  280. #define SOCKET_ECONNREFUSED FCL_ECONNREFUSED
  281. #define SOCKET_ECONNABORTED FNS_ECONNABORTED
  282. #elif defined(WOLFSSL_LWIP_NATIVE)
  283. #define SOCKET_EWOULDBLOCK ERR_WOULDBLOCK
  284. #define SOCKET_EAGAIN ERR_WOULDBLOCK
  285. #define SOCKET_ECONNRESET ERR_RST
  286. #define SOCKET_EINTR ERR_CLSD
  287. #define SOCKET_EPIPE ERR_CLSD
  288. #define SOCKET_ECONNREFUSED ERR_CONN
  289. #define SOCKET_ECONNABORTED ERR_ABRT
  290. #elif defined(WOLFSSL_EMNET)
  291. #include <IP/IP.h>
  292. #define SOCKET_EWOULDBLOCK IP_ERR_WOULD_BLOCK
  293. #define SOCKET_EAGAIN IP_ERR_WOULD_BLOCK
  294. #define SOCKET_ECONNRESET IP_ERR_CONN_RESET
  295. #define SOCKET_EINTR IP_ERR_FAULT
  296. #define SOCKET_EPIPE IP_ERR_PIPE
  297. #define SOCKET_ECONNREFUSED IP_ERR_CONN_REFUSED
  298. #define SOCKET_ECONNABORTED IP_ERR_CONN_ABORTED
  299. #else
  300. #define SOCKET_EWOULDBLOCK EWOULDBLOCK
  301. #define SOCKET_EAGAIN EAGAIN
  302. #define SOCKET_ECONNRESET ECONNRESET
  303. #define SOCKET_EINTR EINTR
  304. #define SOCKET_EPIPE EPIPE
  305. #define SOCKET_ECONNREFUSED ECONNREFUSED
  306. #define SOCKET_ECONNABORTED ECONNABORTED
  307. #endif /* USE_WINDOWS_API */
  308. #ifdef DEVKITPRO
  309. /* from network.h */
  310. #include <network.h>
  311. #define SEND_FUNCTION net_send
  312. #define RECV_FUNCTION net_recv
  313. #elif defined(WOLFSSL_ESPIDF)
  314. #define SEND_FUNCTION send
  315. #define RECV_FUNCTION recv
  316. #if !defined(HAVE_SOCKADDR) && !defined(WOLFSSL_NO_SOCK)
  317. #define HAVE_SOCKADDR
  318. #endif
  319. #elif defined(WOLFSSL_LWIP) && !defined(WOLFSSL_APACHE_MYNEWT)
  320. #define SEND_FUNCTION lwip_send
  321. #define RECV_FUNCTION lwip_recv
  322. #elif defined(WOLFSSL_PICOTCP)
  323. #define SEND_FUNCTION pico_send
  324. #define RECV_FUNCTION pico_recv
  325. #elif defined(FREERTOS_TCP)
  326. #define RECV_FUNCTION(a,b,c,d) FreeRTOS_recv((Socket_t)(a),(void*)(b), (size_t)(c), (BaseType_t)(d))
  327. #define SEND_FUNCTION(a,b,c,d) FreeRTOS_send((Socket_t)(a),(void*)(b), (size_t)(c), (BaseType_t)(d))
  328. #elif defined(WOLFSSL_VXWORKS)
  329. /*socket.h already has "typedef struct sockaddr SOCKADDR;"
  330. so don't redefine it in wolfSSL */
  331. #define HAVE_SOCKADDR_DEFINED
  332. #define SEND_FUNCTION send
  333. #define RECV_FUNCTION recv
  334. #elif defined(WOLFSSL_NUCLEUS_1_2)
  335. #define SEND_FUNCTION NU_Send
  336. #define RECV_FUNCTION NU_Recv
  337. #elif defined(FUSION_RTOS)
  338. #define SEND_FUNCTION FNS_SEND
  339. #define RECV_FUNCTION FNS_RECV
  340. #elif defined(WOLFSSL_ZEPHYR)
  341. #ifndef WOLFSSL_MAX_SEND_SZ
  342. #define WOLFSSL_MAX_SEND_SZ 256
  343. #endif
  344. #define SEND_FUNCTION send
  345. #define RECV_FUNCTION recv
  346. #elif defined(WOLFSSL_LINUXKM)
  347. #define SEND_FUNCTION linuxkm_send
  348. #define RECV_FUNCTION linuxkm_recv
  349. #elif defined(WOLFSSL_SGX)
  350. #define SEND_FUNCTION send
  351. #define RECV_FUNCTION recv
  352. #else
  353. #define SEND_FUNCTION send
  354. #define RECV_FUNCTION recv
  355. #if !defined(HAVE_SOCKADDR) && !defined(WOLFSSL_NO_SOCK)
  356. #define HAVE_SOCKADDR
  357. #endif
  358. #endif
  359. #ifdef USE_WINDOWS_API
  360. #if defined(__MINGW64__)
  361. typedef size_t SOCKET_T;
  362. #else
  363. typedef unsigned int SOCKET_T;
  364. #endif
  365. #ifndef SOCKET_INVALID
  366. #define SOCKET_INVALID INVALID_SOCKET
  367. #endif
  368. #else
  369. typedef int SOCKET_T;
  370. #ifndef SOCKET_INVALID
  371. #define SOCKET_INVALID (-1)
  372. #endif
  373. #endif
  374. #ifndef WOLFSSL_NO_SOCK
  375. #ifndef XSOCKLENT
  376. #ifdef USE_WINDOWS_API
  377. #define XSOCKLENT int
  378. #else
  379. #define XSOCKLENT socklen_t
  380. #endif
  381. #endif
  382. #ifndef XSOCKOPT_TYPE_OPTVAL_TYPE
  383. #ifdef USE_WINDOWS_API
  384. #define XSOCKOPT_TYPE_OPTVAL_TYPE void*
  385. #else
  386. #define XSOCKOPT_TYPE_OPTVAL_TYPE char*
  387. #endif
  388. #endif
  389. /* Socket Addr Support */
  390. #ifdef HAVE_SOCKADDR
  391. #ifndef HAVE_SOCKADDR_DEFINED
  392. typedef struct sockaddr SOCKADDR;
  393. #endif
  394. typedef struct sockaddr_storage SOCKADDR_S;
  395. typedef struct sockaddr_in SOCKADDR_IN;
  396. #ifdef WOLFSSL_IPV6
  397. typedef struct sockaddr_in6 SOCKADDR_IN6;
  398. #endif
  399. typedef struct hostent HOSTENT;
  400. #endif /* HAVE_SOCKADDR */
  401. #if defined(HAVE_GETADDRINFO)
  402. typedef struct addrinfo ADDRINFO;
  403. #endif
  404. #endif /* WOLFSSL_NO_SOCK */
  405. /* IO API's */
  406. #ifdef HAVE_IO_TIMEOUT
  407. WOLFSSL_API int wolfIO_SetBlockingMode(SOCKET_T sockfd, int non_blocking);
  408. WOLFSSL_API void wolfIO_SetTimeout(int to_sec);
  409. WOLFSSL_API int wolfIO_Select(SOCKET_T sockfd, int to_sec);
  410. #endif
  411. WOLFSSL_API int wolfIO_TcpConnect(SOCKET_T* sockfd, const char* ip,
  412. unsigned short port, int to_sec);
  413. #ifdef HAVE_SOCKADDR
  414. WOLFSSL_API int wolfIO_TcpAccept(SOCKET_T sockfd, SOCKADDR* peer_addr, XSOCKLENT* peer_len);
  415. #endif
  416. WOLFSSL_API int wolfIO_TcpBind(SOCKET_T* sockfd, word16 port);
  417. WOLFSSL_API int wolfIO_Send(SOCKET_T sd, char *buf, int sz, int wrFlags);
  418. WOLFSSL_API int wolfIO_Recv(SOCKET_T sd, char *buf, int sz, int rdFlags);
  419. #endif /* USE_WOLFSSL_IO || HAVE_HTTP_CLIENT */
  420. #ifndef WOLFSSL_NO_SOCK
  421. #ifdef USE_WINDOWS_API
  422. #ifndef CloseSocket
  423. #define CloseSocket(s) closesocket(s)
  424. #endif
  425. #define StartTCP() { WSADATA wsd; WSAStartup(0x0002, &wsd); }
  426. #elif defined(WOLFSSL_MDK_ARM) || defined(WOLFSSL_KEIL_TCP_NET)
  427. #ifndef CloseSocket
  428. extern int closesocket(int);
  429. #define CloseSocket(s) closesocket(s)
  430. #endif
  431. #define StartTCP() WC_DO_NOTHING
  432. #elif defined(FUSION_RTOS)
  433. #ifndef CloseSocket
  434. #define CloseSocket(s) do { \
  435. int err; \
  436. FNS_CLOSE(s, &err); \
  437. } while(0)
  438. #endif
  439. #else
  440. #ifndef CloseSocket
  441. #define CloseSocket(s) close(s)
  442. #endif
  443. #define StartTCP() WC_DO_NOTHING
  444. #ifdef FREERTOS_TCP_WINSIM
  445. extern int close(int);
  446. #endif
  447. #endif
  448. #endif /* WOLFSSL_NO_SOCK */
  449. WOLFSSL_API int BioSend(WOLFSSL* ssl, char *buf, int sz, void *ctx);
  450. WOLFSSL_API int BioReceive(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  451. #if defined(USE_WOLFSSL_IO)
  452. /* default IO callbacks */
  453. WOLFSSL_API int EmbedReceive(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  454. WOLFSSL_API int EmbedSend(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  455. #ifdef WOLFSSL_DTLS
  456. WOLFSSL_API int EmbedReceiveFrom(WOLFSSL *ssl, char *buf, int sz,
  457. void *ctx);
  458. WOLFSSL_API int EmbedSendTo(WOLFSSL* ssl, char *buf, int sz, void *ctx);
  459. WOLFSSL_API int EmbedGenerateCookie(WOLFSSL* ssl, byte *buf, int sz,
  460. void *ctx);
  461. #ifdef WOLFSSL_MULTICAST
  462. WOLFSSL_API int EmbedReceiveFromMcast(WOLFSSL *ssl, char *buf,
  463. int sz, void *ctx);
  464. #endif /* WOLFSSL_MULTICAST */
  465. #endif /* WOLFSSL_DTLS */
  466. #endif /* USE_WOLFSSL_IO */
  467. #ifdef HAVE_OCSP
  468. WOLFSSL_API int wolfIO_HttpBuildRequestOcsp(const char* domainName,
  469. const char* path, int ocspReqSz, unsigned char* buf, int bufSize);
  470. WOLFSSL_API int wolfIO_HttpProcessResponseOcsp(int sfd,
  471. unsigned char** respBuf, unsigned char* httpBuf, int httpBufSz,
  472. void* heap);
  473. WOLFSSL_API int EmbedOcspLookup(void* ctx, const char* url, int urlSz,
  474. byte* ocspReqBuf, int ocspReqSz, byte** ocspRespBuf);
  475. WOLFSSL_API void EmbedOcspRespFree(void* ctx, byte *resp);
  476. #endif
  477. #ifdef HAVE_CRL_IO
  478. WOLFSSL_API int wolfIO_HttpBuildRequestCrl(const char* url, int urlSz,
  479. const char* domainName, unsigned char* buf, int bufSize);
  480. WOLFSSL_API int wolfIO_HttpProcessResponseCrl(WOLFSSL_CRL* crl, int sfd,
  481. unsigned char* httpBuf, int httpBufSz);
  482. WOLFSSL_API int EmbedCrlLookup(WOLFSSL_CRL* crl, const char* url,
  483. int urlSz);
  484. #endif
  485. #if defined(HAVE_HTTP_CLIENT)
  486. WOLFSSL_API int wolfIO_DecodeUrl(const char* url, int urlSz, char* outName,
  487. char* outPath, unsigned short* outPort);
  488. WOLFSSL_API int wolfIO_HttpBuildRequest(const char* reqType,
  489. const char* domainName, const char* path, int pathLen, int reqSz,
  490. const char* contentType, unsigned char* buf, int bufSize);
  491. WOLFSSL_LOCAL int wolfIO_HttpBuildRequest_ex(const char* reqType,
  492. const char* domainName, const char* path, int pathLen, int reqSz,
  493. const char* contentType, const char *exHdrs, unsigned char* buf, int bufSize);
  494. WOLFSSL_API int wolfIO_HttpProcessResponse(int sfd, const char** appStrList,
  495. unsigned char** respBuf, unsigned char* httpBuf, int httpBufSz,
  496. int dynType, void* heap);
  497. #endif /* HAVE_HTTP_CLIENT */
  498. /* I/O callbacks */
  499. typedef int (*CallbackIORecv)(WOLFSSL *ssl, char *buf, int sz, void *ctx);
  500. typedef int (*CallbackIOSend)(WOLFSSL *ssl, char *buf, int sz, void *ctx);
  501. WOLFSSL_API void wolfSSL_CTX_SetIORecv(WOLFSSL_CTX *ctx, CallbackIORecv CBIORecv);
  502. WOLFSSL_API void wolfSSL_CTX_SetIOSend(WOLFSSL_CTX *ctx, CallbackIOSend CBIOSend);
  503. WOLFSSL_API void wolfSSL_SSLSetIORecv(WOLFSSL *ssl, CallbackIORecv CBIORecv);
  504. WOLFSSL_API void wolfSSL_SSLSetIOSend(WOLFSSL *ssl, CallbackIOSend CBIOSend);
  505. /* deprecated old name */
  506. #define wolfSSL_SetIORecv wolfSSL_CTX_SetIORecv
  507. #define wolfSSL_SetIOSend wolfSSL_CTX_SetIOSend
  508. WOLFSSL_API void wolfSSL_SetIOReadCtx( WOLFSSL* ssl, void *ctx);
  509. WOLFSSL_API void wolfSSL_SetIOWriteCtx(WOLFSSL* ssl, void *ctx);
  510. WOLFSSL_API void* wolfSSL_GetIOReadCtx( WOLFSSL* ssl);
  511. WOLFSSL_API void* wolfSSL_GetIOWriteCtx(WOLFSSL* ssl);
  512. WOLFSSL_API void wolfSSL_SetIOReadFlags( WOLFSSL* ssl, int flags);
  513. WOLFSSL_API void wolfSSL_SetIOWriteFlags(WOLFSSL* ssl, int flags);
  514. #ifdef HAVE_NETX
  515. WOLFSSL_LOCAL int NetX_Receive(WOLFSSL *ssl, char *buf, int sz, void *ctx);
  516. WOLFSSL_LOCAL int NetX_Send(WOLFSSL *ssl, char *buf, int sz, void *ctx);
  517. WOLFSSL_API void wolfSSL_SetIO_NetX(WOLFSSL* ssl, NX_TCP_SOCKET* nxsocket,
  518. ULONG waitoption);
  519. #endif /* HAVE_NETX */
  520. #ifdef MICRIUM
  521. WOLFSSL_LOCAL int MicriumSend(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  522. WOLFSSL_LOCAL int MicriumReceive(WOLFSSL* ssl, char* buf, int sz,
  523. void* ctx);
  524. WOLFSSL_LOCAL int MicriumReceiveFrom(WOLFSSL* ssl, char* buf, int sz,
  525. void* ctx);
  526. WOLFSSL_LOCAL int MicriumSendTo(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  527. #endif /* MICRIUM */
  528. #if defined(WOLFSSL_APACHE_MYNEWT) && !defined(WOLFSSL_LWIP)
  529. WOLFSSL_LOCAL int Mynewt_Receive(WOLFSSL *ssl, char *buf, int sz, void *ctx);
  530. WOLFSSL_LOCAL int Mynewt_Send(WOLFSSL* ssl, char *buf, int sz, void *ctx);
  531. WOLFSSL_API void wolfSSL_SetIO_Mynewt(WOLFSSL* ssl, struct mn_socket* mnSocket,
  532. struct mn_sockaddr_in* mnSockAddrIn);
  533. #endif /* defined(WOLFSSL_APACHE_MYNEWT) && !defined(WOLFSSL_LWIP) */
  534. #ifdef WOLFSSL_UIP
  535. struct uip_wolfssl_ctx {
  536. union socket_connector {
  537. struct tcp_socket tcp;
  538. struct udp_socket udp;
  539. } conn;
  540. WOLFSSL_CTX *ctx;
  541. WOLFSSL *ssl;
  542. byte *input_databuf;
  543. byte *output_databuf;
  544. byte *ssl_rx_databuf;
  545. int ssl_rb_len;
  546. int ssl_rb_off;
  547. struct process *process;
  548. tcp_socket_data_callback_t input_callback;
  549. tcp_socket_event_callback_t event_callback;
  550. int closing;
  551. uip_ipaddr_t peer_addr;
  552. word16 peer_port;
  553. };
  554. typedef struct uip_wolfssl_ctx uip_wolfssl_ctx;
  555. WOLFSSL_LOCAL int uIPSend(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  556. WOLFSSL_LOCAL int uIPReceive(WOLFSSL* ssl, char* buf, int sz,
  557. void* ctx);
  558. WOLFSSL_LOCAL int uIPReceiveFrom(WOLFSSL* ssl, char* buf, int sz,
  559. void* ctx);
  560. WOLFSSL_LOCAL int uIPSendTo(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  561. #endif
  562. #ifdef WOLFSSL_GNRC
  563. #include <sock_types.h>
  564. #include <net/gnrc.h>
  565. #include <net/af.h>
  566. #include <net/sock.h>
  567. #include <net/gnrc/tcp.h>
  568. #include <net/gnrc/udp.h>
  569. struct gnrc_wolfssl_ctx {
  570. union socket_connector {
  571. #ifdef MODULE_SOCK_TCP
  572. sock_tcp_t tcp;
  573. #endif
  574. sock_udp_t udp;
  575. } conn;
  576. WOLFSSL_CTX *ctx;
  577. WOLFSSL *ssl;
  578. int closing;
  579. struct _sock_tl_ep peer_addr;
  580. };
  581. typedef struct gnrc_wolfssl_ctx sock_tls_t;
  582. WOLFSSL_LOCAL int GNRC_ReceiveFrom(WOLFSSL* ssl, char* buf, int sz,
  583. void* ctx);
  584. WOLFSSL_LOCAL int GNRC_SendTo(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  585. #endif
  586. #ifdef WOLFSSL_LWIP_NATIVE
  587. #include "lwip/tcp.h"
  588. #include "lwip/sockets.h"
  589. typedef struct WOLFSSL_LWIP_NATIVE_STATE {
  590. struct tcp_pcb * pcb;
  591. tcp_recv_fn recv_fn;
  592. tcp_sent_fn sent_fn;
  593. int pulled;
  594. struct pbuf *pbuf;
  595. int wait;
  596. void * arg; /* arg for application */
  597. int idle_count;
  598. } WOLFSSL_LWIP_NATIVE_STATE;
  599. WOLFSSL_LOCAL int LwIPNativeSend(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  600. WOLFSSL_LOCAL int LwIPNativeReceive(WOLFSSL* ssl, char* buf, int sz,
  601. void* ctx);
  602. WOLFSSL_API int wolfSSL_SetIO_LwIP(WOLFSSL* ssl, void *pcb,
  603. tcp_recv_fn recv, tcp_sent_fn sent, void *arg);
  604. #endif
  605. #ifdef WOLFSSL_ISOTP
  606. #define ISOTP_DEFAULT_TIMEOUT 100
  607. #define ISOTP_DEFAULT_WAIT_COUNT 3
  608. #define ISOTP_FIRST_FRAME_DATA_SIZE 6
  609. #define ISOTP_SINGLE_FRAME_DATA_SIZE 7
  610. #define ISOTP_MAX_CONSECUTIVE_FRAME_DATA_SIZE 7
  611. #define ISOTP_MAX_MS_FRAME_DELAY 0x7f
  612. #define ISOTP_CAN_BUS_PAYLOAD_SIZE 8
  613. #define ISOTP_MAX_DATA_SIZE 4095
  614. /* Packets will never be larger than the ISO-TP max data size */
  615. #define ISOTP_DEFAULT_BUFFER_SIZE ISOTP_MAX_DATA_SIZE
  616. #define ISOTP_FLOW_CONTROL_PACKET_SIZE 3
  617. #define ISOTP_FLOW_CONTROL_FRAMES 0 /* infinite */
  618. #define ISOTP_MAX_SEQUENCE_COUNTER 15
  619. enum isotp_frame_type {
  620. ISOTP_FRAME_TYPE_SINGLE = 0,
  621. ISOTP_FRAME_TYPE_FIRST = 1,
  622. ISOTP_FRAME_TYPE_CONSECUTIVE = 2,
  623. ISOTP_FRAME_TYPE_CONTROL = 3
  624. };
  625. enum isotp_flow_control {
  626. ISOTP_FLOW_CONTROL_CTS = 0,
  627. ISOTP_FLOW_CONTROL_WAIT = 1,
  628. ISOTP_FLOW_CONTROL_ABORT = 2
  629. };
  630. enum isotp_connection_state {
  631. ISOTP_CONN_STATE_IDLE,
  632. ISOTP_CONN_STATE_SENDING,
  633. ISOTP_CONN_STATE_RECEIVING
  634. };
  635. typedef struct isotp_can_data {
  636. byte data[ISOTP_CAN_BUS_PAYLOAD_SIZE];
  637. byte length;
  638. } isotp_can_data;
  639. /* User supplied functions for sending/receiving CAN bus messages of up to
  640. * 8 bytes, as well as a function to add an artificial delay when a
  641. * receiver requests one. */
  642. typedef int (*can_recv_fn)(struct isotp_can_data *data, void *arg,
  643. int timeout);
  644. typedef int (*can_send_fn)(struct isotp_can_data *data, void *arg);
  645. typedef void (*can_delay_fn)(int microseconds);
  646. typedef struct isotp_wolfssl_ctx {
  647. struct isotp_can_data frame;
  648. char *buf_ptr;
  649. char *receive_buffer;
  650. char *receive_buffer_ptr;
  651. can_recv_fn recv_fn;
  652. can_send_fn send_fn;
  653. can_delay_fn delay_fn;
  654. void *arg;
  655. int receive_buffer_len;
  656. int receive_buffer_size;
  657. enum isotp_connection_state state;
  658. word16 buf_length;
  659. byte sequence;
  660. byte flow_packets;
  661. byte flow_counter;
  662. byte frame_delay;
  663. byte wait_counter;
  664. byte receive_delay;
  665. } isotp_wolfssl_ctx;
  666. WOLFSSL_LOCAL int ISOTP_Receive(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  667. WOLFSSL_LOCAL int ISOTP_Send(WOLFSSL* ssl, char* buf, int sz, void* ctx);
  668. WOLFSSL_API int wolfSSL_SetIO_ISOTP(WOLFSSL *ssl, isotp_wolfssl_ctx *ctx,
  669. can_recv_fn recv_fn, can_send_fn send_fn, can_delay_fn delay_fn,
  670. word32 receive_delay, char *receive_buffer,
  671. int receive_buffer_size, void *arg);
  672. #endif
  673. #ifdef WOLFSSL_DTLS
  674. typedef int (*CallbackGenCookie)(WOLFSSL* ssl, unsigned char* buf, int sz,
  675. void* ctx);
  676. WOLFSSL_API void wolfSSL_CTX_SetGenCookie(WOLFSSL_CTX* ctx,
  677. CallbackGenCookie cb);
  678. WOLFSSL_API void wolfSSL_SetCookieCtx(WOLFSSL* ssl, void *ctx);
  679. WOLFSSL_API void* wolfSSL_GetCookieCtx(WOLFSSL* ssl);
  680. #endif
  681. #ifdef WOLFSSL_SESSION_EXPORT
  682. typedef int (*CallbackGetPeer)(WOLFSSL* ssl, char* ip, int* ipSz,
  683. unsigned short* port, int* fam);
  684. typedef int (*CallbackSetPeer)(WOLFSSL* ssl, char* ip, int ipSz,
  685. unsigned short port, int fam);
  686. WOLFSSL_API void wolfSSL_CTX_SetIOGetPeer(WOLFSSL_CTX*, CallbackGetPeer);
  687. WOLFSSL_API void wolfSSL_CTX_SetIOSetPeer(WOLFSSL_CTX*, CallbackSetPeer);
  688. WOLFSSL_API int EmbedGetPeer(WOLFSSL* ssl, char* ip, int* ipSz,
  689. unsigned short* port, int* fam);
  690. WOLFSSL_API int EmbedSetPeer(WOLFSSL* ssl, char* ip, int ipSz,
  691. unsigned short port, int fam);
  692. #endif /* WOLFSSL_SESSION_EXPORT */
  693. #ifndef XINET_NTOP
  694. #define XINET_NTOP(a,b,c,d) inet_ntop((a),(b),(c),(d))
  695. #ifdef USE_WINDOWS_API /* Windows-friendly definition */
  696. #undef XINET_NTOP
  697. #define XINET_NTOP(a,b,c,d) InetNtop((a),(b),(c),(d))
  698. #endif
  699. #endif
  700. #ifndef XINET_PTON
  701. #define XINET_PTON(a,b,c) inet_pton((a),(b),(c))
  702. #ifdef USE_WINDOWS_API /* Windows-friendly definition */
  703. #undef XINET_PTON
  704. #if defined(__MINGW64__) && !defined(UNICODE)
  705. #define XINET_PTON(a,b,c) InetPton((a),(b),(c))
  706. #else
  707. #define XINET_PTON(a,b,c) InetPton((a),(PCWSTR)(b),(c))
  708. #endif
  709. #endif
  710. #endif
  711. #ifndef XHTONS
  712. #if !defined(WOLFSSL_NO_SOCK) && (defined(USE_WOLFSSL_IO) || defined(HAVE_HTTP_CLIENT))
  713. #define XHTONS(a) htons((a))
  714. #else
  715. /* we don't have sockets, so define our own htons and ntohs */
  716. #ifdef BIG_ENDIAN_ORDER
  717. #define XHTONS(a) (a)
  718. #else
  719. #define XHTONS(a) ((((a) >> 8) & 0xff) | (((a) & 0xff) << 8))
  720. #endif
  721. #endif
  722. #endif
  723. #ifndef XNTOHS
  724. #if !defined(WOLFSSL_NO_SOCK) && (defined(USE_WOLFSSL_IO) || defined(HAVE_HTTP_CLIENT))
  725. #define XNTOHS(a) ntohs((a))
  726. #else
  727. /* we don't have sockets, so define our own htons and ntohs */
  728. #ifdef BIG_ENDIAN_ORDER
  729. #define XNTOHS(a) (a)
  730. #else
  731. #define XNTOHS(a) ((((a) >> 8) & 0xff) | (((a) & 0xff) << 8))
  732. #endif
  733. #endif
  734. #endif
  735. #ifndef WOLFSSL_IP4
  736. #define WOLFSSL_IP4 AF_INET
  737. #endif
  738. #ifndef WOLFSSL_IP6
  739. #define WOLFSSL_IP6 AF_INET6
  740. #endif
  741. #ifdef __cplusplus
  742. } /* extern "C" */
  743. #endif
  744. #endif /* WOLFSSL_IO_H */