eal: add error numbers in thread TLS API
Add error number reporting to rte_errno in all functions in the rte_thread_tls_* API. Suggested-by: Anatoly Burakov <anatoly.burakov@intel.com> Signed-off-by: Tal Shnaiderman <talshn@nvidia.com> Acked-by: Dmitry Kozlyuk <dmitry.kozliuk@gmail.com>
This commit is contained in:
parent
defd7f5a53
commit
3d2913c67c
@ -63,7 +63,9 @@ void rte_thread_get_affinity(rte_cpuset_t *cpusetp);
|
||||
*
|
||||
* @return
|
||||
* On success, zero.
|
||||
* On failure, a negative number.
|
||||
* On failure, a negative number and an error number is set in rte_errno.
|
||||
* rte_errno can be: ENOMEM - Memory allocation error.
|
||||
* ENOEXEC - Specific OS error.
|
||||
*/
|
||||
|
||||
__rte_experimental
|
||||
@ -77,7 +79,9 @@ int rte_thread_tls_key_create(rte_tls_key *key, void (*destructor)(void *));
|
||||
*
|
||||
* @return
|
||||
* On success, zero.
|
||||
* On failure, a negative number.
|
||||
* On failure, a negative number and an error number is set in rte_errno.
|
||||
* rte_errno can be: EINVAL - Invalid parameter passed.
|
||||
* ENOEXEC - Specific OS error.
|
||||
*/
|
||||
__rte_experimental
|
||||
int rte_thread_tls_key_delete(rte_tls_key key);
|
||||
@ -92,7 +96,9 @@ int rte_thread_tls_key_delete(rte_tls_key key);
|
||||
*
|
||||
* @return
|
||||
* On success, zero.
|
||||
* On failure, a negative number.
|
||||
* On failure, a negative number and an error number is set in rte_errno.
|
||||
* rte_errno can be: EINVAL - Invalid parameter passed.
|
||||
* ENOEXEC - Specific OS error.
|
||||
*/
|
||||
__rte_experimental
|
||||
int rte_thread_tls_value_set(rte_tls_key key, const void *value);
|
||||
@ -106,6 +112,8 @@ int rte_thread_tls_value_set(rte_tls_key key, const void *value);
|
||||
* @return
|
||||
* On success, value data pointer (can also be NULL).
|
||||
* On failure, NULL and an error number is set in rte_errno.
|
||||
* rte_errno can be: EINVAL - Invalid parameter passed.
|
||||
* ENOEXEC - Specific OS error.
|
||||
*/
|
||||
__rte_experimental
|
||||
void *rte_thread_tls_value_get(rte_tls_key key);
|
||||
|
@ -24,6 +24,7 @@ rte_thread_tls_key_create(rte_tls_key *key, void (*destructor)(void *))
|
||||
*key = malloc(sizeof(**key));
|
||||
if ((*key) == NULL) {
|
||||
RTE_LOG(DEBUG, EAL, "Cannot allocate TLS key.\n");
|
||||
rte_errno = ENOMEM;
|
||||
return -1;
|
||||
}
|
||||
err = pthread_key_create(&((*key)->thread_index), destructor);
|
||||
@ -31,6 +32,7 @@ rte_thread_tls_key_create(rte_tls_key *key, void (*destructor)(void *))
|
||||
RTE_LOG(DEBUG, EAL, "pthread_key_create failed: %s\n",
|
||||
strerror(err));
|
||||
free(*key);
|
||||
rte_errno = ENOEXEC;
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
@ -43,6 +45,7 @@ rte_thread_tls_key_delete(rte_tls_key key)
|
||||
|
||||
if (!key) {
|
||||
RTE_LOG(DEBUG, EAL, "Invalid TLS key.\n");
|
||||
rte_errno = EINVAL;
|
||||
return -1;
|
||||
}
|
||||
err = pthread_key_delete(key->thread_index);
|
||||
@ -50,6 +53,7 @@ rte_thread_tls_key_delete(rte_tls_key key)
|
||||
RTE_LOG(DEBUG, EAL, "pthread_key_delete failed: %s\n",
|
||||
strerror(err));
|
||||
free(key);
|
||||
rte_errno = ENOEXEC;
|
||||
return -1;
|
||||
}
|
||||
free(key);
|
||||
@ -63,12 +67,14 @@ rte_thread_tls_value_set(rte_tls_key key, const void *value)
|
||||
|
||||
if (!key) {
|
||||
RTE_LOG(DEBUG, EAL, "Invalid TLS key.\n");
|
||||
rte_errno = EINVAL;
|
||||
return -1;
|
||||
}
|
||||
err = pthread_setspecific(key->thread_index, value);
|
||||
if (err) {
|
||||
RTE_LOG(DEBUG, EAL, "pthread_setspecific failed: %s\n",
|
||||
strerror(err));
|
||||
rte_errno = ENOEXEC;
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
|
@ -18,12 +18,14 @@ rte_thread_tls_key_create(rte_tls_key *key,
|
||||
*key = malloc(sizeof(**key));
|
||||
if ((*key) == NULL) {
|
||||
RTE_LOG(DEBUG, EAL, "Cannot allocate TLS key.\n");
|
||||
rte_errno = ENOMEM;
|
||||
return -1;
|
||||
}
|
||||
(*key)->thread_index = TlsAlloc();
|
||||
if ((*key)->thread_index == TLS_OUT_OF_INDEXES) {
|
||||
RTE_LOG_WIN32_ERR("TlsAlloc()");
|
||||
free(*key);
|
||||
rte_errno = ENOEXEC;
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
@ -34,11 +36,13 @@ rte_thread_tls_key_delete(rte_tls_key key)
|
||||
{
|
||||
if (!key) {
|
||||
RTE_LOG(DEBUG, EAL, "Invalid TLS key.\n");
|
||||
rte_errno = EINVAL;
|
||||
return -1;
|
||||
}
|
||||
if (!TlsFree(key->thread_index)) {
|
||||
RTE_LOG_WIN32_ERR("TlsFree()");
|
||||
free(key);
|
||||
rte_errno = ENOEXEC;
|
||||
return -1;
|
||||
}
|
||||
free(key);
|
||||
@ -52,12 +56,14 @@ rte_thread_tls_value_set(rte_tls_key key, const void *value)
|
||||
|
||||
if (!key) {
|
||||
RTE_LOG(DEBUG, EAL, "Invalid TLS key.\n");
|
||||
rte_errno = EINVAL;
|
||||
return -1;
|
||||
}
|
||||
/* discard const qualifier */
|
||||
p = (char *) (uintptr_t) value;
|
||||
if (!TlsSetValue(key->thread_index, p)) {
|
||||
RTE_LOG_WIN32_ERR("TlsSetValue()");
|
||||
rte_errno = ENOEXEC;
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
|
Loading…
Reference in New Issue
Block a user