pdump: fix log messages
[dpdk.git] / lib / librte_pdump / rte_pdump.c
index 70efd96..5968683 100644 (file)
@@ -225,29 +225,6 @@ pdump_tx(uint8_t port __rte_unused, uint16_t qidx __rte_unused,
        return nb_pkts;
 }
 
-static int
-pdump_get_dombdf(char *device_id, char *domBDF, size_t len)
-{
-       int ret;
-       struct rte_pci_addr dev_addr = {0};
-
-       /* identify if device_id is pci address or name */
-       ret = eal_parse_pci_DomBDF(device_id, &dev_addr);
-       if (ret < 0)
-               return -1;
-
-       if (dev_addr.domain)
-               ret = snprintf(domBDF, len, "%u:%u:%u.%u", dev_addr.domain,
-                               dev_addr.bus, dev_addr.devid,
-                               dev_addr.function);
-       else
-               ret = snprintf(domBDF, len, "%u:%u.%u", dev_addr.bus,
-                               dev_addr.devid,
-                               dev_addr.function);
-
-       return ret;
-}
-
 static int
 pdump_regitser_rx_callbacks(uint16_t end_q, uint8_t port, uint16_t queue,
                                struct rte_ring *ring, struct rte_mempool *mp,
@@ -292,7 +269,7 @@ pdump_regitser_rx_callbacks(uint16_t end_q, uint8_t port, uint16_t queue,
                        if (ret < 0) {
                                RTE_LOG(ERR, PDUMP,
                                        "failed to remove rx callback, errno=%d\n",
-                                       rte_errno);
+                                       -ret);
                                return ret;
                        }
                        cbs->cb = NULL;
@@ -347,7 +324,7 @@ pdump_regitser_tx_callbacks(uint16_t end_q, uint8_t port, uint16_t queue,
                        if (ret < 0) {
                                RTE_LOG(ERR, PDUMP,
                                        "failed to remove tx callback, errno=%d\n",
-                                       rte_errno);
+                                       -ret);
                                return ret;
                        }
                        cbs->cb = NULL;
@@ -443,12 +420,13 @@ set_pdump_rxtx_cbs(struct pdump_request *p)
 }
 
 /* get socket path (/var/run if root, $HOME otherwise) */
-static void
+static int
 pdump_get_socket_path(char *buffer, int bufsz, enum rte_pdump_socktype type)
 {
        char dpdk_dir[PATH_MAX] = {0};
        char dir[PATH_MAX] = {0};
        char *dir_home = NULL;
+       int ret = 0;
 
        if (type == RTE_PDUMP_SOCKET_SERVER && server_socket_dir[0] != 0)
                snprintf(dir, sizeof(dir), "%s", server_socket_dir);
@@ -457,23 +435,41 @@ pdump_get_socket_path(char *buffer, int bufsz, enum rte_pdump_socktype type)
        else {
                if (getuid() != 0) {
                        dir_home = getenv(SOCKET_PATH_HOME);
+                       if (!dir_home) {
+                               RTE_LOG(ERR, PDUMP,
+                                       "Failed to get environment variable"
+                                       " value for %s, %s:%d\n",
+                                       SOCKET_PATH_HOME, __func__, __LINE__);
+                               return -1;
+                       }
                        snprintf(dpdk_dir, sizeof(dpdk_dir), "%s%s",
                                        dir_home, DPDK_DIR);
                } else
                        snprintf(dpdk_dir, sizeof(dpdk_dir), "%s%s",
                                        SOCKET_PATH_VAR_RUN, DPDK_DIR);
 
-               mkdir(dpdk_dir, 700);
+               mkdir(dpdk_dir, 0700);
                snprintf(dir, sizeof(dir), "%s%s",
                                        dpdk_dir, SOCKET_DIR);
        }
 
-       mkdir(dir, 700);
+       ret =  mkdir(dir, 0700);
+       /* if user passed socket path is invalid, return immediately */
+       if (ret < 0 && errno != EEXIST) {
+               RTE_LOG(ERR, PDUMP,
+                       "Failed to create dir:%s:%s\n", dir,
+                       strerror(errno));
+               rte_errno = errno;
+               return -1;
+       }
+
        if (type == RTE_PDUMP_SOCKET_SERVER)
                snprintf(buffer, bufsz, SERVER_SOCKET, dir);
        else
                snprintf(buffer, bufsz, CLIENT_SOCKET, dir, getpid(),
                                rte_sys_gettid());
+
+       return 0;
 }
 
 static int
@@ -483,8 +479,14 @@ pdump_create_server_socket(void)
        struct sockaddr_un addr;
        socklen_t addr_len;
 
-       pdump_get_socket_path(addr.sun_path, sizeof(addr.sun_path),
+       ret = pdump_get_socket_path(addr.sun_path, sizeof(addr.sun_path),
                                RTE_PDUMP_SOCKET_SERVER);
+       if (ret != 0) {
+               RTE_LOG(ERR, PDUMP,
+                       "Failed to get server socket path: %s:%d\n",
+                       __func__, __LINE__);
+               return -1;
+       }
        addr.sun_family = AF_UNIX;
 
        /* remove if file already exists */
@@ -615,8 +617,14 @@ rte_pdump_uninit(void)
 
        struct sockaddr_un addr;
 
-       pdump_get_socket_path(addr.sun_path, sizeof(addr.sun_path),
+       ret = pdump_get_socket_path(addr.sun_path, sizeof(addr.sun_path),
                                RTE_PDUMP_SOCKET_SERVER);
+       if (ret != 0) {
+               RTE_LOG(ERR, PDUMP,
+                       "Failed to get server socket path: %s:%d\n",
+                       __func__, __LINE__);
+               return -1;
+       }
        ret = unlink(addr.sun_path);
        if (ret != 0) {
                RTE_LOG(ERR, PDUMP,
@@ -646,12 +654,19 @@ pdump_create_client_socket(struct pdump_request *p)
                        "client socket(): %s:pid(%d):tid(%u), %s:%d\n",
                        strerror(errno), pid, rte_sys_gettid(),
                        __func__, __LINE__);
-               ret = errno;
-               return ret;
+               rte_errno = errno;
+               return -1;
        }
 
-       pdump_get_socket_path(addr.sun_path, sizeof(addr.sun_path),
+       ret = pdump_get_socket_path(addr.sun_path, sizeof(addr.sun_path),
                                RTE_PDUMP_SOCKET_CLIENT);
+       if (ret != 0) {
+               RTE_LOG(ERR, PDUMP,
+                       "Failed to get client socket path: %s:%d\n",
+                       __func__, __LINE__);
+               rte_errno = errno;
+               goto exit;
+       }
        addr.sun_family = AF_UNIX;
        addr_len = sizeof(struct sockaddr_un);
 
@@ -661,15 +676,22 @@ pdump_create_client_socket(struct pdump_request *p)
                        RTE_LOG(ERR, PDUMP,
                                "client bind(): %s, %s:%d\n",
                                strerror(errno), __func__, __LINE__);
-                       ret = errno;
+                       rte_errno = errno;
                        break;
                }
 
                serv_len = sizeof(struct sockaddr_un);
                memset(&serv_addr, 0, sizeof(serv_addr));
-               pdump_get_socket_path(serv_addr.sun_path,
+               ret = pdump_get_socket_path(serv_addr.sun_path,
                                        sizeof(serv_addr.sun_path),
                                        RTE_PDUMP_SOCKET_SERVER);
+               if (ret != 0) {
+                       RTE_LOG(ERR, PDUMP,
+                               "Failed to get server socket path: %s:%d\n",
+                               __func__, __LINE__);
+                       rte_errno = errno;
+                       break;
+               }
                serv_addr.sun_family = AF_UNIX;
 
                n =  sendto(socket_fd, p, sizeof(struct pdump_request), 0,
@@ -678,7 +700,8 @@ pdump_create_client_socket(struct pdump_request *p)
                        RTE_LOG(ERR, PDUMP,
                                "failed to send to server:%s, %s:%d\n",
                                strerror(errno), __func__, __LINE__);
-                       ret =  errno;
+                       rte_errno = errno;
+                       ret = -1;
                        break;
                }
 
@@ -689,12 +712,14 @@ pdump_create_client_socket(struct pdump_request *p)
                        RTE_LOG(ERR, PDUMP,
                                "failed to recv from server:%s, %s:%d\n",
                                strerror(errno), __func__, __LINE__);
-                       ret = errno;
+                       rte_errno = errno;
+                       ret = -1;
                        break;
                }
                ret = server_resp.err_value;
        } while (0);
 
+exit:
        close(socket_fd);
        unlink(addr.sun_path);
        return ret;
@@ -777,13 +802,15 @@ pdump_prepare_client_request(char *device, uint16_t queue,
        req.flags = flags;
        req.op =  operation;
        if ((operation & ENABLE) != 0) {
-               strncpy(req.data.en_v1.device, device, strlen(device));
+               snprintf(req.data.en_v1.device, sizeof(req.data.en_v1.device),
+                               "%s", device);
                req.data.en_v1.queue = queue;
                req.data.en_v1.ring = ring;
                req.data.en_v1.mp = mp;
                req.data.en_v1.filter = filter;
        } else {
-               strncpy(req.data.dis_v1.device, device, strlen(device));
+               snprintf(req.data.dis_v1.device, sizeof(req.data.dis_v1.device),
+                               "%s", device);
                req.data.dis_v1.queue = queue;
                req.data.dis_v1.ring = NULL;
                req.data.dis_v1.mp = NULL;
@@ -835,7 +862,6 @@ rte_pdump_enable_by_deviceid(char *device_id, uint16_t queue,
                                void *filter)
 {
        int ret = 0;
-       char domBDF[DEVICE_ID_SIZE];
 
        ret = pdump_validate_ring_mp(ring, mp);
        if (ret < 0)
@@ -844,11 +870,7 @@ rte_pdump_enable_by_deviceid(char *device_id, uint16_t queue,
        if (ret < 0)
                return ret;
 
-       if (pdump_get_dombdf(device_id, domBDF, sizeof(domBDF)) > 0)
-               ret = pdump_prepare_client_request(domBDF, queue, flags,
-                                               ENABLE, ring, mp, filter);
-       else
-               ret = pdump_prepare_client_request(device_id, queue, flags,
+       ret = pdump_prepare_client_request(device_id, queue, flags,
                                                ENABLE, ring, mp, filter);
 
        return ret;
@@ -878,17 +900,12 @@ rte_pdump_disable_by_deviceid(char *device_id, uint16_t queue,
                                uint32_t flags)
 {
        int ret = 0;
-       char domBDF[DEVICE_ID_SIZE];
 
        ret = pdump_validate_flags(flags);
        if (ret < 0)
                return ret;
 
-       if (pdump_get_dombdf(device_id, domBDF, sizeof(domBDF)) > 0)
-               ret = pdump_prepare_client_request(domBDF, queue, flags,
-                                               DISABLE, NULL, NULL, NULL);
-       else
-               ret = pdump_prepare_client_request(device_id, queue, flags,
+       ret = pdump_prepare_client_request(device_id, queue, flags,
                                                DISABLE, NULL, NULL, NULL);
 
        return ret;