09/10/2021 09:41, Narcisa Ana Maria Vasile:
> From: Narcisa Vasile <navas...@microsoft.com>
> 
> Add function to translate Windows error codes to
> errno-style error codes. The possible return values are chosen
> so that we have as much semantical compatibility between platforms as
> possible.
> 
> Signed-off-by: Narcisa Vasile <navas...@microsoft.com>
> ---
>  lib/eal/common/rte_thread.c  |  6 +--
>  lib/eal/include/rte_thread.h |  5 +-
>  lib/eal/windows/rte_thread.c | 95 +++++++++++++++++++++++++++---------
>  3 files changed, 76 insertions(+), 30 deletions(-)
> 
> diff --git a/lib/eal/common/rte_thread.c b/lib/eal/common/rte_thread.c
> index e1a4d7eae4..27ad1c7eb0 100644
> --- a/lib/eal/common/rte_thread.c
> +++ b/lib/eal/common/rte_thread.c
> @@ -47,7 +47,7 @@ rte_thread_attr_init(rte_thread_attr_t *attr)
>  
>  int
>  rte_thread_attr_set_affinity(rte_thread_attr_t *thread_attr,
> -                          rte_cpuset_t *cpuset)
> +             rte_cpuset_t *cpuset)
>  {
>       RTE_VERIFY(thread_attr != NULL);
>       RTE_VERIFY(cpuset != NULL);
> @@ -59,7 +59,7 @@ rte_thread_attr_set_affinity(rte_thread_attr_t *thread_attr,
>  
>  int
>  rte_thread_attr_get_affinity(rte_thread_attr_t *thread_attr,
> -                          rte_cpuset_t *cpuset)
> +             rte_cpuset_t *cpuset)
>  {
>       RTE_VERIFY(thread_attr != NULL);
>       RTE_VERIFY(cpuset != NULL);
> @@ -71,7 +71,7 @@ rte_thread_attr_get_affinity(rte_thread_attr_t *thread_attr,
>  
>  int
>  rte_thread_attr_set_priority(rte_thread_attr_t *thread_attr,
> -                          enum rte_thread_priority priority)
> +             enum rte_thread_priority priority)

Above are unrelated changes.

> --- a/lib/eal/windows/rte_thread.c
> +++ b/lib/eal/windows/rte_thread.c
> @@ -13,6 +13,54 @@ struct eal_tls_key {
>       DWORD thread_index;
>  };
>  
> +/* Translates the most common error codes related to threads */
> +static int
> +thread_translate_win32_error(DWORD error)

So you decide to adopt POSIX error codes for the DPDK API. OK

> +{
> +     switch (error) {
> +     case ERROR_SUCCESS:
> +             return 0;
> +
> +     case ERROR_INVALID_PARAMETER:
> +             return EINVAL;
> +
> +     case ERROR_INVALID_HANDLE:
> +             return EFAULT;
> +
> +     case ERROR_NOT_ENOUGH_MEMORY:
> +     /* FALLTHROUGH */
> +     case ERROR_NO_SYSTEM_RESOURCES:
> +             return ENOMEM;
> +
> +     case ERROR_PRIVILEGE_NOT_HELD:
> +     /* FALLTHROUGH */
> +     case ERROR_ACCESS_DENIED:
> +             return EACCES;
> +
> +     case ERROR_ALREADY_EXISTS:
> +             return EEXIST;
> +
> +     case ERROR_POSSIBLE_DEADLOCK:
> +             return EDEADLK;
> +
> +     case ERROR_INVALID_FUNCTION:
> +     /* FALLTHROUGH */
> +     case ERROR_CALL_NOT_IMPLEMENTED:
> +             return ENOSYS;
> +     }
> +
> +     return EINVAL;
> +}
[...]
>  rte_thread_key_create(rte_thread_key *key,
>               __rte_unused void (*destructor)(void *))
>  {
> +     int ret;
> +
>       *key = malloc(sizeof(**key));
>       if ((*key) == NULL) {
>               RTE_LOG(DEBUG, EAL, "Cannot allocate TLS key.\n");
> -             rte_errno = ENOMEM;
> -             return -1;
> +             return ENOMEM;
>       }

Why this change? rte_errno and negative error code are good.



Reply via email to