code cleanup, memleak fixed on the client side;
This commit is contained in:
		
							parent
							
								
									ef36409851
								
							
						
					
					
						commit
						56a6f24df1
					
				| @ -35,6 +35,7 @@ | |||||||
| 
 | 
 | ||||||
| #include <openssl/ssl.h> | #include <openssl/ssl.h> | ||||||
| #include <openssl/err.h> | #include <openssl/err.h> | ||||||
|  | #include <openssl/engine.h> | ||||||
| 
 | 
 | ||||||
| #include <tdata/usrtc.h> | #include <tdata/usrtc.h> | ||||||
| #include <tdata/list.h> | #include <tdata/list.h> | ||||||
| @ -385,6 +386,11 @@ void sntl_finalize(void) | |||||||
|   OPENSSL_free(lock_cs); |   OPENSSL_free(lock_cs); | ||||||
|   OPENSSL_free(lock_count); |   OPENSSL_free(lock_count); | ||||||
| 
 | 
 | ||||||
|  |   ERR_free_strings(); | ||||||
|  |   ENGINE_cleanup(); | ||||||
|  |   CRYPTO_cleanup_all_ex_data(); | ||||||
|  |   EVP_cleanup(); | ||||||
|  | 
 | ||||||
|   return; |   return; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -544,6 +550,7 @@ static void __connection_destroy(conn_t *co) | |||||||
| 
 | 
 | ||||||
|   /* free queue */ |   /* free queue */ | ||||||
|   ERR_remove_state(0); |   ERR_remove_state(0); | ||||||
|  |   ERR_remove_thread_state(0); | ||||||
| 
 | 
 | ||||||
|   /* update use count */ |   /* update use count */ | ||||||
|   usleep(1500); |   usleep(1500); | ||||||
| @ -580,28 +587,18 @@ static void __connection_destroy(conn_t *co) | |||||||
|     if(co->pctx->login) free(co->pctx->login); |     if(co->pctx->login) free(co->pctx->login); | ||||||
|     if(co->pctx->passwd) free(co->pctx->passwd); |     if(co->pctx->passwd) free(co->pctx->passwd); | ||||||
| 
 | 
 | ||||||
|     /*while((fd = SSL_shutdown(co->ssl)) != 1) {
 |  | ||||||
|       if(fd < 0) break; |  | ||||||
|       }*/ |  | ||||||
|     SSL_set_shutdown(co->ssl, SSL_RECEIVED_SHUTDOWN | SSL_SENT_SHUTDOWN); |     SSL_set_shutdown(co->ssl, SSL_RECEIVED_SHUTDOWN | SSL_SENT_SHUTDOWN); | ||||||
| 
 | 
 | ||||||
|     fd = SSL_get_fd(co->ssl); |     fd = SSL_get_fd(co->ssl); | ||||||
|     //int ti = CRYPTO_add(&co->ssl->references, -1, CRYPTO_LOCK_SSL);
 | 
 | ||||||
|     //printf("ti = %d;\n", ti);
 |  | ||||||
|     SSL_free(co->ssl); |     SSL_free(co->ssl); | ||||||
|     //SSL_CTX_free(co->ssys->ctx);
 |  | ||||||
|     co->ssl = NULL; |     co->ssl = NULL; | ||||||
| 
 | 
 | ||||||
|     ERR_remove_thread_state(0); |     ERR_remove_thread_state(0); | ||||||
|     ERR_remove_state(0); |     ERR_remove_state(0); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     //ENGINE_cleanup();
 |  | ||||||
|     //CRYPTO_cleanup_all_ex_data();
 |  | ||||||
|     ERR_free_strings(); |     ERR_free_strings(); | ||||||
|     //ERR_remove_state(0);
 |  | ||||||
|     //EVP_cleanup();
 |  | ||||||
|     //    ENGINE_cleanup();
 |  | ||||||
| 
 | 
 | ||||||
|     close(fd); |     close(fd); | ||||||
|     __connection_second_free(co); |     __connection_second_free(co); | ||||||
| @ -1327,7 +1324,10 @@ conn_t *connection_link(conn_sys_t *ssys, const char *host, | |||||||
|     if(!bundle) goto __fail5; |     if(!bundle) goto __fail5; | ||||||
|     r = pthread_create(&co->thrd_poll[i], NULL, __sntll_thread, bundle); |     r = pthread_create(&co->thrd_poll[i], NULL, __sntll_thread, bundle); | ||||||
|     if(r) goto __fail5; |     if(r) goto __fail5; | ||||||
|     else bundle = (void *)0xdead; |     else { | ||||||
|  |       pthread_detach(co->thrd_poll[i]); | ||||||
|  |       bundle = (void *)0xdead; | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   /* all is done, connection now ready */ |   /* all is done, connection now ready */ | ||||||
| @ -1345,6 +1345,9 @@ conn_t *connection_link(conn_sys_t *ssys, const char *host, | |||||||
|  __fail2: |  __fail2: | ||||||
|   if(buf != MAP_FAILED) munmap(buf, 65536); |   if(buf != MAP_FAILED) munmap(buf, 65536); | ||||||
|   SSL_shutdown(co->ssl); |   SSL_shutdown(co->ssl); | ||||||
|  |   ERR_remove_thread_state(0); | ||||||
|  |   ERR_remove_state(0); | ||||||
|  | 
 | ||||||
|   close(sck); |   close(sck); | ||||||
|  __fail: |  __fail: | ||||||
|   if(co) { |   if(co) { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user