X-Git-Url: https://git.openssl.org/gitweb/?p=openssl.git;a=blobdiff_plain;f=crypto%2Fbio%2Fbss_sock.c;h=30c3ceab468cf1ca50a9bb65e8f51dbda014d727;hp=cfd2f119921056eae137a4e460439a53a44bdc5a;hb=636b6b450dcc0c694780ea34ed2f5d4a39d5d9b5;hpb=74d7abc2ab54e725f7cfbc2fa7bad95f93e4dc63 diff --git a/crypto/bio/bss_sock.c b/crypto/bio/bss_sock.c index cfd2f11992..30c3ceab46 100644 --- a/crypto/bio/bss_sock.c +++ b/crypto/bio/bss_sock.c @@ -56,55 +56,29 @@ * [including the GNU Public Licence.] */ -#if !defined(NO_SOCK) || defined(BIO_FD) - #include #include #define USE_SOCKETS #include "cryptlib.h" -#include "bio.h" -#ifndef BIO_FD -#ifndef NOPROTO -static int sock_write(BIO *h,char *buf,int num); -static int sock_read(BIO *h,char *buf,int size); -static int sock_puts(BIO *h,char *str); -static long sock_ctrl(BIO *h,int cmd,long arg1,char *arg2); -static int sock_new(BIO *h); -static int sock_free(BIO *data); -int BIO_sock_should_retry(int s); -#else -static int sock_write(); -static int sock_read(); -static int sock_puts(); -static long sock_ctrl(); -static int sock_new(); -static int sock_free(); -int BIO_sock_should_retry(); -#endif +#ifndef OPENSSL_NO_SOCK -#else +#include -#ifndef NOPROTO -static int fd_write(BIO *h,char *buf,int num); -static int fd_read(BIO *h,char *buf,int size); -static int fd_puts(BIO *h,char *str); -static long fd_ctrl(BIO *h,int cmd,long arg1,char *arg2); -static int fd_new(BIO *h); -static int fd_free(BIO *data); -int BIO_fd_should_retry(int s); -#else -static int fd_write(); -static int fd_read(); -static int fd_puts(); -static long fd_ctrl(); -static int fd_new(); -static int fd_free(); -int BIO_fd_should_retry(); -#endif +#ifdef WATT32 +#define sock_write SockWrite /* Watt-32 uses same names */ +#define sock_read SockRead +#define sock_puts SockPuts #endif -#ifndef BIO_FD +static int sock_write(BIO *h, const char *buf, int num); +static int sock_read(BIO *h, char *buf, int size); +static int sock_puts(BIO *h, const char *str); +static long sock_ctrl(BIO *h, int cmd, long arg1, void *arg2); +static int sock_new(BIO *h); +static int sock_free(BIO *data); +int BIO_sock_should_retry(int s); + static BIO_METHOD methods_sockp= { BIO_TYPE_SOCKET, @@ -116,57 +90,25 @@ static BIO_METHOD methods_sockp= sock_ctrl, sock_new, sock_free, + NULL, }; -BIO_METHOD *BIO_s_socket() +BIO_METHOD *BIO_s_socket(void) { return(&methods_sockp); } -#else -static BIO_METHOD methods_fdp= - { - BIO_TYPE_FD,"file descriptor", - fd_write, - fd_read, - fd_puts, - NULL, /* fd_gets, */ - fd_ctrl, - fd_new, - fd_free, - }; - -BIO_METHOD *BIO_s_fd() - { - return(&methods_fdp); - } -#endif -#ifndef BIO_FD -BIO *BIO_new_socket(fd,close_flag) -#else -BIO *BIO_new_fd(fd,close_flag) -#endif -int fd; -int close_flag; +BIO *BIO_new_socket(int fd, int close_flag) { BIO *ret; -#ifndef BIO_FD ret=BIO_new(BIO_s_socket()); -#else - ret=BIO_new(BIO_s_fd()); -#endif if (ret == NULL) return(NULL); BIO_set_fd(ret,fd,close_flag); return(ret); } -#ifndef BIO_FD -static int sock_new(bi) -#else -static int fd_new(bi) -#endif -BIO *bi; +static int sock_new(BIO *bi) { bi->init=0; bi->num=0; @@ -175,25 +117,14 @@ BIO *bi; return(1); } -#ifndef BIO_FD -static int sock_free(a) -#else -static int fd_free(a) -#endif -BIO *a; +static int sock_free(BIO *a) { if (a == NULL) return(0); if (a->shutdown) { if (a->init) { -#ifndef BIO_FD - shutdown(a->num,2); - closesocket(a->num); -#else /* BIO_FD */ - close(a->num); -#endif - + SHUTDOWN2(a->num); } a->init=0; a->flags=0; @@ -201,80 +132,40 @@ BIO *a; return(1); } -#ifndef BIO_FD -static int sock_read(b,out,outl) -#else -static int fd_read(b,out,outl) -#endif -BIO *b; -char *out; -int outl; +static int sock_read(BIO *b, char *out, int outl) { int ret=0; if (out != NULL) { -#ifndef BIO_FD clear_socket_error(); ret=readsocket(b->num,out,outl); -#else - clear_sys_error(); - ret=read(b->num,out,outl); -#endif BIO_clear_retry_flags(b); if (ret <= 0) { -#ifndef BIO_FD if (BIO_sock_should_retry(ret)) -#else - if (BIO_fd_should_retry(ret)) -#endif BIO_set_retry_read(b); } } return(ret); } -#ifndef BIO_FD -static int sock_write(b,in,inl) -#else -static int fd_write(b,in,inl) -#endif -BIO *b; -char *in; -int inl; +static int sock_write(BIO *b, const char *in, int inl) { int ret; -#ifndef BIO_FD clear_socket_error(); ret=writesocket(b->num,in,inl); -#else - clear_sys_error(); - ret=write(b->num,in,inl); -#endif BIO_clear_retry_flags(b); if (ret <= 0) { -#ifndef BIO_FD if (BIO_sock_should_retry(ret)) -#else - if (BIO_fd_should_retry(ret)) -#endif BIO_set_retry_write(b); } return(ret); } -#ifndef BIO_FD -static long sock_ctrl(b,cmd,num,ptr) -#else -static long fd_ctrl(b,cmd,num,ptr) -#endif -BIO *b; -int cmd; -long num; -char *ptr; +static long sock_ctrl(BIO *b, int cmd, long num, void *ptr) { long ret=1; int *ip; @@ -284,26 +175,14 @@ char *ptr; case BIO_CTRL_RESET: num=0; case BIO_C_FILE_SEEK: -#ifdef BIO_FD - ret=(long)lseek(b->num,num,0); -#else ret=0; -#endif break; case BIO_C_FILE_TELL: case BIO_CTRL_INFO: -#ifdef BIO_FD - ret=(long)lseek(b->num,0,1); -#else ret=0; -#endif break; case BIO_C_SET_FD: -#ifndef BIO_FD sock_free(b); -#else - fd_free(b); -#endif b->num= *((int *)ptr); b->shutdown=(int)num; b->init=1; @@ -339,76 +218,38 @@ char *ptr; return(ret); } -#ifdef undef -static int sock_gets(bp,buf,size) -BIO *bp; -char *buf; -int size; - { - return(-1); - } -#endif - -#ifndef BIO_FD -static int sock_puts(bp,str) -#else -static int fd_puts(bp,str) -#endif -BIO *bp; -char *str; +static int sock_puts(BIO *bp, const char *str) { int n,ret; n=strlen(str); -#ifndef BIO_FD ret=sock_write(bp,str,n); -#else - ret=fd_write(bp,str,n); -#endif return(ret); } -#ifndef BIO_FD -int BIO_sock_should_retry(i) -#else -int BIO_fd_should_retry(i) -#endif -int i; +int BIO_sock_should_retry(int i) { int err; if ((i == 0) || (i == -1)) { -#ifndef BIO_FD err=get_last_socket_error(); -#else - err=get_last_sys_error(); -#endif -#if defined(WINDOWS) && 0 /* more microsoft stupidity? perhaps not? Ben 4/1/99 */ +#if defined(OPENSSL_SYS_WINDOWS) && 0 /* more microsoft stupidity? perhaps not? Ben 4/1/99 */ if ((i == -1) && (err == 0)) return(1); #endif -#ifndef BIO_FD return(BIO_sock_non_fatal_error(err)); -#else - return(BIO_fd_non_fatal_error(err)); -#endif } return(0); } -#ifndef BIO_FD -int BIO_sock_non_fatal_error(err) -#else -int BIO_fd_non_fatal_error(err) -#endif -int err; +int BIO_sock_non_fatal_error(int err) { switch (err) { -#if !defined(BIO_FD) && defined(WINDOWS) +#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_NETWARE) # if defined(WSAEWOULDBLOCK) case WSAEWOULDBLOCK: # endif @@ -439,7 +280,7 @@ int err; #endif #ifdef EAGAIN -#if EWOULDBLOCK != EAGAIN +# if EWOULDBLOCK != EAGAIN case EAGAIN: # endif #endif @@ -462,4 +303,5 @@ int err; } return(0); } -#endif + +#endif /* #ifndef OPENSSL_NO_SOCK */