🐞fix(hos_write): 修复hash_hos_info分配问题导致的内存错乱

This commit is contained in:
彭宣正
2021-04-07 14:54:30 +08:00
parent 6bb183780c
commit b3c9951471

View File

@@ -81,7 +81,7 @@ typedef struct hos_client_handle_s
hos_client_handle g_hos_handle;//一个进程只允许有一个g_hos_handle hos_client_handle g_hos_handle;//一个进程只允许有一个g_hos_handle
//hos_info_t *hash_hos_info[MAX_HOS_CLIENT_THREAD_NUM]; //hos_info_t *hash_hos_info[MAX_HOS_CLIENT_THREAD_NUM];
hos_info_t *hash_hos_info; hos_info_t **hash_hos_info;
size_t *hos_cache;//记录当前hos缓存了多少数据 size_t *hos_cache;//记录当前hos缓存了多少数据
size_t (*fd_info)[MAX_HOS_CLIENT_FD_NUM + 1]; //fd 实际从3开始 fd[thread_id][0]记录register的fdfd[thread_id][1]记录inject的fd size_t (*fd_info)[MAX_HOS_CLIENT_FD_NUM + 1]; //fd 实际从3开始 fd[thread_id][0]记录register的fdfd[thread_id][1]记录inject的fd
Aws::SDKOptions g_options; Aws::SDKOptions g_options;
@@ -198,6 +198,11 @@ void hos_set_thread_sum(hos_client_handle client, size_t thread_sum)
{ {
return; return;
} }
if (client->thread_sum >= thread_sum )
{
return;
}
client->thread_sum = thread_sum; client->thread_sum = thread_sum;
for (size_t i = 0; i < thread_sum; i++) for (size_t i = 0; i < thread_sum; i++)
{ {
@@ -209,7 +214,17 @@ void hos_set_thread_sum(hos_client_handle client, size_t thread_sum)
} }
if (hash_hos_info) if (hash_hos_info)
{ {
hash_hos_info = (hos_info_t *)realloc(hash_hos_info, thread_sum * sizeof(hos_info_t)); hash_hos_info = (hos_info_t **)realloc(hash_hos_info, thread_sum * sizeof(hos_info_t*));
}else
{
hash_hos_info = (hos_info_t **)calloc(thread_sum, sizeof(hos_info_t*));
}
if (fd_info)
{
fd_info = (size_t (*) [MAX_HOS_CLIENT_FD_NUM + 1])realloc(fd_info, thread_sum * sizeof(size_t [MAX_HOS_CLIENT_FD_NUM + 1]));
}else
{
fd_info = (size_t (*) [MAX_HOS_CLIENT_FD_NUM + 1])calloc(thread_sum, sizeof(size_t [MAX_HOS_CLIENT_FD_NUM + 1]));
} }
return ; return ;
} }
@@ -269,7 +284,8 @@ hos_client_handle hos_client_create(const char *serverip, size_t port, const cha
g_hos_handle->executor = std::dynamic_pointer_cast<Aws::Utils::Threading::PooledThreadExecutor>(config.executor); g_hos_handle->executor = std::dynamic_pointer_cast<Aws::Utils::Threading::PooledThreadExecutor>(config.executor);
hos_cache = (size_t *)calloc(g_hos_handle->thread_sum, sizeof(size_t)); hos_cache = (size_t *)calloc(g_hos_handle->thread_sum, sizeof(size_t));
hash_hos_info = (hos_info_t *)calloc(1, sizeof(hos_info_t)); hash_hos_info = (hos_info_t **)calloc(1, sizeof(hos_info_t *));
fd_info = (size_t (*)[MAX_HOS_CLIENT_FD_NUM + 1])calloc(1, sizeof(size_t [MAX_HOS_CLIENT_FD_NUM + 1]));
fd_info[0][0] = 65533; fd_info[0][0] = 65533;
fd_info[0][1] = 0; fd_info[0][1] = 0;
@@ -754,7 +770,7 @@ int hos_write(size_t fd, const char *stream, size_t stream_len, size_t thread_id
int ret = 0; int ret = 0;
data_info_t *data_info = NULL; data_info_t *data_info = NULL;
if ((fd == 0) || (stream == NULL) || (thread_id > MAX_HOS_CLIENT_THREAD_NUM)) if ((fd == 0) || (stream == NULL) || (thread_id > g_hos_handle->thread_sum))
{ {
return HOS_PARAMETER_ERROR; return HOS_PARAMETER_ERROR;
} }
@@ -1038,10 +1054,21 @@ int hos_client_destory(hos_client_handle handle)
free(hos_cache); free(hos_cache);
} }
if (fd_info)
{
free(fd_info);
}
for (i = 0; i < handle->thread_sum; i++) for (i = 0; i < handle->thread_sum; i++)
{ {
delete_all(&hash_hos_info[i]); delete_all(&hash_hos_info[i]);
} }
if (hash_hos_info)
{
free(hash_hos_info);
}
free(handle); free(handle);
Aws::ShutdownAPI(g_options); Aws::ShutdownAPI(g_options);