diff options
| author | Linus Nordberg <linus@nordu.net> | 2016-04-18 15:02:38 +0200 | 
|---|---|---|
| committer | Linus Nordberg <linus@nordu.net> | 2016-09-21 13:12:54 +0200 | 
| commit | c928c63f85a91305a063e1dfe705d86d30f35dbf (patch) | |
| tree | 7ca02a19f836290aef9050e30658bedcf3309ecf | |
| parent | 46e97b761ccf654120e65f394317adbe49720bcf (diff) | |
Stomp less on other threads memory.
See RADSECPROXY-64.
| -rw-r--r-- | tcp.c | 10 | ||||
| -rw-r--r-- | tls.c | 10 | 
2 files changed, 16 insertions, 4 deletions
| @@ -321,6 +321,7 @@ void *tcpservernew(void *arg) {      struct client *client;      s = *(int *)arg; +    free(arg);      if (getpeername(s, (struct sockaddr *)&from, &fromlen)) {  	debug(DBG_DBG, "tcpservernew: getpeername failed, exiting");  	goto exit; @@ -348,7 +349,7 @@ exit:  void *tcplistener(void *arg) {      pthread_t tcpserverth; -    int s, *sp = (int *)arg; +    int s, *sp = (int *)arg, *s_arg = NULL;      struct sockaddr_storage from;      socklen_t fromlen = sizeof(from); @@ -360,8 +361,13 @@ void *tcplistener(void *arg) {  	    debug(DBG_WARN, "accept failed");  	    continue;  	} -	if (pthread_create(&tcpserverth, &pthread_attr, tcpservernew, (void *)&s)) { +        s_arg = malloc(sizeof(s)); +        if (!s_arg) +            debugx(1, DBG_ERR, "malloc failed"); +        *s_arg = s; +	if (pthread_create(&tcpserverth, &pthread_attr, tcpservernew, (void *) s_arg)) {  	    debug(DBG_ERR, "tcplistener: pthread_create failed"); +            free(s_arg);  	    shutdown(s, SHUT_RDWR);  	    close(s);  	    continue; @@ -402,6 +402,7 @@ void *tlsservernew(void *arg) {      struct tls *accepted_tls = NULL;      s = *(int *)arg; +    free(arg);      if (getpeername(s, (struct sockaddr *)&from, &fromlen)) {  	debug(DBG_DBG, "tlsservernew: getpeername failed, exiting");  	goto exit; @@ -462,7 +463,7 @@ exit:  void *tlslistener(void *arg) {      pthread_t tlsserverth; -    int s, *sp = (int *)arg; +    int s, *sp = (int *)arg, *s_arg = NULL;      struct sockaddr_storage from;      socklen_t fromlen = sizeof(from); @@ -474,8 +475,13 @@ void *tlslistener(void *arg) {  	    debug(DBG_WARN, "accept failed");  	    continue;  	} -	if (pthread_create(&tlsserverth, &pthread_attr, tlsservernew, (void *)&s)) { +        s_arg = malloc(sizeof(s)); +        if (!s_arg) +            debugx(1, DBG_ERR, "malloc failed"); +        *s_arg = s; +	if (pthread_create(&tlsserverth, &pthread_attr, tlsservernew, (void *) s_arg)) {  	    debug(DBG_ERR, "tlslistener: pthread_create failed"); +            free(s_arg);  	    shutdown(s, SHUT_RDWR);  	    close(s);  	    continue; | 
