diff options
author | Florin Coras <fcoras@cisco.com> | 2024-03-18 12:25:38 -0700 |
---|---|---|
committer | Dave Barach <vpp@barachs.net> | 2024-03-25 18:53:05 +0000 |
commit | 8ae63db02066a2b5ac18a89fd63dc0dd2a811ab3 (patch) | |
tree | 0d7877f1c8bd18ce9dd4f32cfddfa3e4f557bc35 | |
parent | a8d266a7a4bf1188739dcd6d3ddcc8173282d95d (diff) |
vcl: add api to retrieve num bytes for tx
Type: improvement
Signed-off-by: Florin Coras <fcoras@cisco.com>
Change-Id: Iaa1b026e2baea1c03f8c75e7d6879d0ff6d379d6
-rw-r--r-- | src/vcl/ldp.c | 8 | ||||
-rw-r--r-- | src/vcl/vppcom.c | 14 | ||||
-rw-r--r-- | src/vcl/vppcom.h | 1 |
3 files changed, 21 insertions, 2 deletions
diff --git a/src/vcl/ldp.c b/src/vcl/ldp.c index 566b5a858a3..bd3457fa8fd 100644 --- a/src/vcl/ldp.c +++ b/src/vcl/ldp.c @@ -613,7 +613,13 @@ ioctl (int fd, unsigned long int cmd, ...) case FIONREAD: rv = vls_attr (vlsh, VPPCOM_ATTR_GET_NREAD, 0, 0); break; - + case TIOCOUTQ: + { + u32 *buf = va_arg (ap, void *); + u32 *buflen = va_arg (ap, u32 *); + rv = vls_attr (vlsh, VPPCOM_ATTR_GET_NWRITEQ, buf, buflen); + } + break; case FIONBIO: { u32 flags = *(va_arg (ap, int *)) ? O_NONBLOCK : 0; diff --git a/src/vcl/vppcom.c b/src/vcl/vppcom.c index a0a0336c787..a0bbae170f8 100644 --- a/src/vcl/vppcom.c +++ b/src/vcl/vppcom.c @@ -3585,7 +3585,19 @@ vppcom_session_attr (uint32_t session_handle, uint32_t op, VDBG (2, "VPPCOM_ATTR_GET_NWRITE: sh %u, nwrite = %d", session_handle, rv); break; - + case VPPCOM_ATTR_GET_NWRITEQ: + if (PREDICT_FALSE (!buffer || !buflen || *buflen != sizeof (int))) + { + rv = VPPCOM_EINVAL; + break; + } + if (!session->tx_fifo || session->session_state == VCL_STATE_DETACHED) + { + rv = VPPCOM_EINVAL; + break; + } + *(int *) buffer = svm_fifo_max_dequeue (session->tx_fifo); + break; case VPPCOM_ATTR_GET_FLAGS: if (PREDICT_TRUE (buffer && buflen && (*buflen >= sizeof (*flags)))) { diff --git a/src/vcl/vppcom.h b/src/vcl/vppcom.h index 5683cb2cf0b..386d7d0c3f7 100644 --- a/src/vcl/vppcom.h +++ b/src/vcl/vppcom.h @@ -184,6 +184,7 @@ typedef enum VPPCOM_ATTR_SET_IP_PKTINFO, VPPCOM_ATTR_GET_IP_PKTINFO, VPPCOM_ATTR_GET_ORIGINAL_DST, + VPPCOM_ATTR_GET_NWRITEQ, } vppcom_attr_op_t; typedef struct _vcl_poll |