From 8e2a720b3da9fae85c97dd065e4ca4f656ab9287 Mon Sep 17 00:00:00 2001 From: Federico Aponte Date: Thu, 30 May 2024 21:26:53 +0200 Subject: [PATCH] fix: multiple definitions for scap_engine_handle Signed-off-by: Federico Aponte --- userspace/libscap/engine/bpf/scap_bpf.c | 38 ++++----- userspace/libscap/engine/gvisor/gvisor.cpp | 18 ++--- userspace/libscap/engine/kmod/scap_kmod.c | 78 +++++++++---------- .../engine/modern_bpf/scap_modern_bpf.c | 38 ++++----- userspace/libscap/engine/nodriver/nodriver.c | 2 +- userspace/libscap/engine/noop/noop.c | 4 +- .../libscap/engine/savefile/scap_savefile.c | 8 +- .../engine/source_plugin/source_plugin.c | 6 +- .../libscap/engine/test_input/test_input.c | 2 +- userspace/libscap/engine_handle.h | 6 +- userspace/libscap/scap_vtable.h | 2 +- 11 files changed, 99 insertions(+), 103 deletions(-) diff --git a/userspace/libscap/engine/bpf/scap_bpf.c b/userspace/libscap/engine/bpf/scap_bpf.c index c0638efd9cb..7d62382a9d1 100644 --- a/userspace/libscap/engine/bpf/scap_bpf.c +++ b/userspace/libscap/engine/bpf/scap_bpf.c @@ -1163,23 +1163,23 @@ int32_t scap_bpf_stop_capture(struct scap_engine_handle engine) static int32_t calibrate_socket_file_ops(struct scap_engine_handle engine) { /* We just need to enable the socket syscall for the socket calibration */ - engine.m_handle->curr_sc_set.ppm_sc[PPM_SC_SOCKET] = 1; + ((SCAP_HANDLE_T*)engine.m_handle)->curr_sc_set.ppm_sc[PPM_SC_SOCKET] = 1; if(scap_bpf_start_capture(engine) != SCAP_SUCCESS) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "unable to set the socket syscall for the calibration"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "unable to set the socket syscall for the calibration"); } int fd = socket(AF_INET, SOCK_DGRAM, 0); if(fd == -1) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "unable to create a socket for the calibration"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "unable to create a socket for the calibration"); } close(fd); /* We need to stop the capture */ if(scap_bpf_stop_capture(engine) != SCAP_SUCCESS) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "unable to stop the capture after the calibration"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "unable to stop the capture after the calibration"); } return SCAP_SUCCESS; @@ -1881,7 +1881,7 @@ int32_t scap_bpf_get_n_tracepoint_hit(struct scap_engine_handle engine, long* re static int32_t next(struct scap_engine_handle engine, scap_evt **pevent, uint16_t *pdevid, uint32_t *pflags) { - return ringbuffer_next(&engine.m_handle->m_dev_set, pevent, pdevid, pflags); + return ringbuffer_next(&((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set, pevent, pdevid, pflags); } static int32_t unsupported_config(struct scap_engine_handle engine, const char* msg) @@ -1976,7 +1976,7 @@ static int32_t init(scap_t* handle, scap_open_args *oargs) struct scap_bpf_engine_params *params = oargs->engine_params; strlcpy(bpf_probe_buf, params->bpf_probe, SCAP_MAX_PATH_SIZE); - if(check_buffer_bytes_dim(engine.m_handle->m_lasterr, params->buffer_bytes_dim) != SCAP_SUCCESS) + if(check_buffer_bytes_dim(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, params->buffer_bytes_dim) != SCAP_SUCCESS) { return SCAP_FAILURE; } @@ -1987,18 +1987,18 @@ static int32_t init(scap_t* handle, scap_open_args *oargs) ssize_t num_cpus = sysconf(_SC_NPROCESSORS_CONF); if(num_cpus == -1) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "cannot obtain the number of available CPUs from '_SC_NPROCESSORS_CONF'"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "cannot obtain the number of available CPUs from '_SC_NPROCESSORS_CONF'"); } - engine.m_handle->m_ncpus = num_cpus; + ((SCAP_HANDLE_T*)engine.m_handle)->m_ncpus = num_cpus; ssize_t num_devs = sysconf(_SC_NPROCESSORS_ONLN); if(num_devs == -1) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "cannot obtain the number of online CPUs from '_SC_NPROCESSORS_ONLN'"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "cannot obtain the number of online CPUs from '_SC_NPROCESSORS_ONLN'"); } - rc = devset_init(&engine.m_handle->m_dev_set, num_devs, engine.m_handle->m_lasterr); + rc = devset_init(&((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set, num_devs, ((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr); if(rc != SCAP_SUCCESS) { return rc; @@ -2019,12 +2019,12 @@ static int32_t init(scap_t* handle, scap_open_args *oargs) } /* Store interesting sc codes */ - memcpy(&engine.m_handle->curr_sc_set, &oargs->ppm_sc_of_interest, sizeof(interesting_ppm_sc_set)); + memcpy(&((SCAP_HANDLE_T*)engine.m_handle)->curr_sc_set, &oargs->ppm_sc_of_interest, sizeof(interesting_ppm_sc_set)); - engine.m_handle->m_flags = 0; + ((SCAP_HANDLE_T*)engine.m_handle)->m_flags = 0; if(scap_get_bpf_stats_enabled()) { - engine.m_handle->m_flags |= ENGINE_FLAG_BPF_STATS_ENABLED; + ((SCAP_HANDLE_T*)engine.m_handle)->m_flags |= ENGINE_FLAG_BPF_STATS_ENABLED; } return SCAP_SUCCESS; @@ -2032,19 +2032,19 @@ static int32_t init(scap_t* handle, scap_open_args *oargs) static uint64_t get_flags(struct scap_engine_handle engine) { - return engine.m_handle->m_flags; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_flags; } static uint32_t get_n_devs(struct scap_engine_handle engine) { - return engine.m_handle->m_dev_set.m_ndevs; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set.m_ndevs; } static uint64_t get_max_buf_used(struct scap_engine_handle engine) { uint64_t i; uint64_t max = 0; - struct scap_device_set *devset = &engine.m_handle->m_dev_set; + struct scap_device_set *devset = &((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set; for(i = 0; i < devset->m_ndevs; i++) { @@ -2057,19 +2057,19 @@ static uint64_t get_max_buf_used(struct scap_engine_handle engine) uint64_t scap_bpf_get_api_version(struct scap_engine_handle engine) { - return engine.m_handle->m_api_version; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_api_version; } uint64_t scap_bpf_get_schema_version(struct scap_engine_handle engine) { - return engine.m_handle->m_schema_version; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version; } const struct scap_vtable scap_bpf_engine = { .name = BPF_ENGINE, .savefile_ops = NULL, - .alloc_handle = alloc_handle, + .alloc_handle = (void* (*)(scap_t*, char*))alloc_handle, .init = init, .get_flags = get_flags, .free_handle = free_handle, diff --git a/userspace/libscap/engine/gvisor/gvisor.cpp b/userspace/libscap/engine/gvisor/gvisor.cpp index e1ec0145cd0..cebedb9fb0d 100644 --- a/userspace/libscap/engine/gvisor/gvisor.cpp +++ b/userspace/libscap/engine/gvisor/gvisor.cpp @@ -149,34 +149,34 @@ static SCAP_HANDLE_T *gvisor_alloc_handle(scap_t* main_handle, char *lasterr_ptr static int32_t gvisor_init(scap_t* main_handle, scap_open_args* oargs) { - scap_gvisor::engine *gv = main_handle->m_engine.m_handle; + auto gv = (SCAP_HANDLE_T*)main_handle->m_engine.m_handle; struct scap_gvisor_engine_params *params = (struct scap_gvisor_engine_params *)oargs->engine_params; return gv->init(params->gvisor_config_path, params->gvisor_root_path, params->no_events, params->gvisor_epoll_timeout, params->gvisor_platform); } static void gvisor_free_handle(scap_engine_handle engine) { - delete engine.m_handle; + delete (SCAP_HANDLE_T*)engine.m_handle; } static int32_t gvisor_start_capture(scap_engine_handle engine) { - return engine.m_handle->start_capture(); + return ((SCAP_HANDLE_T*)engine.m_handle)->start_capture(); } static int32_t gvisor_close(scap_engine_handle engine) { - return engine.m_handle->close(); + return ((SCAP_HANDLE_T*)engine.m_handle)->close(); } static int32_t gvisor_stop_capture(scap_engine_handle engine) { - return engine.m_handle->stop_capture(); + return ((SCAP_HANDLE_T*)engine.m_handle)->stop_capture(); } static int32_t gvisor_next(scap_engine_handle engine, scap_evt** pevent, uint16_t* pdevid, uint32_t* pflags) { - return engine.m_handle->next(pevent, pdevid, pflags); + return ((SCAP_HANDLE_T*)engine.m_handle)->next(pevent, pdevid, pflags); } static int32_t gvisor_configure(scap_engine_handle engine, scap_setting setting, unsigned long arg1, unsigned long arg2) @@ -186,12 +186,12 @@ static int32_t gvisor_configure(scap_engine_handle engine, scap_setting setting, static int32_t gvisor_get_stats(scap_engine_handle engine, scap_stats* stats) { - return engine.m_handle->get_stats(stats); + return ((SCAP_HANDLE_T*)engine.m_handle)->get_stats(stats); } static const metrics_v2* gvisor_get_stats_v2(scap_engine_handle engine, uint32_t flags, uint32_t* nstats, int32_t* rc) { - return engine.m_handle->get_stats_v2(flags, nstats, rc); + return ((SCAP_HANDLE_T*)engine.m_handle)->get_stats_v2(flags, nstats, rc); } static int32_t gvisor_get_n_tracepoint_hit(scap_engine_handle engine, long* ret) @@ -217,7 +217,7 @@ extern const struct scap_vtable scap_gvisor_engine = { .name = GVISOR_ENGINE, .savefile_ops = nullptr, - .alloc_handle = gvisor_alloc_handle, + .alloc_handle = (void* (*)(scap_t*, char*))gvisor_alloc_handle, .init = gvisor_init, .get_flags = nullptr, .free_handle = gvisor_free_handle, diff --git a/userspace/libscap/engine/kmod/scap_kmod.c b/userspace/libscap/engine/kmod/scap_kmod.c index b2800933075..ff3493a125a 100644 --- a/userspace/libscap/engine/kmod/scap_kmod.c +++ b/userspace/libscap/engine/kmod/scap_kmod.c @@ -347,7 +347,7 @@ int32_t scap_kmod_init(scap_t *handle, scap_open_args *oargs) return scap_errprintf(handle->m_lasterr, errno, "cannot obtain the number of online CPUs from '_SC_NPROCESSORS_ONLN'"); } - rc = devset_init(&engine.m_handle->m_dev_set, ndevs, handle->m_lasterr); + rc = devset_init(&((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set, ndevs, handle->m_lasterr); if(rc != SCAP_SUCCESS) { return rc; @@ -358,7 +358,7 @@ int32_t scap_kmod_init(scap_t *handle, scap_open_args *oargs) // mapped_len = single_buffer_dim * 2; - struct scap_device_set *devset = &engine.m_handle->m_dev_set; + struct scap_device_set *devset = &((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set; uint32_t online_idx = 0; // devset->m_ndevs = online CPUs in the system. // ncpus = available CPUs in the system. @@ -406,7 +406,7 @@ int32_t scap_kmod_init(scap_t *handle, scap_open_args *oargs) return scap_errprintf(handle->m_lasterr, err, "Kernel module does not support PPM_IOCTL_GET_API_VERSION"); } // Make sure all devices report the same API version - if (engine.m_handle->m_api_version != 0 && engine.m_handle->m_api_version != api_version) + if (((SCAP_HANDLE_T*)engine.m_handle)->m_api_version != 0 && ((SCAP_HANDLE_T*)engine.m_handle)->m_api_version != api_version) { int err = errno; close(dev->m_fd); @@ -415,14 +415,14 @@ int32_t scap_kmod_init(scap_t *handle, scap_open_args *oargs) PPM_API_VERSION_MAJOR(api_version), PPM_API_VERSION_MINOR(api_version), PPM_API_VERSION_PATCH(api_version), - PPM_API_VERSION_MAJOR(engine.m_handle->m_api_version), - PPM_API_VERSION_MINOR(engine.m_handle->m_api_version), - PPM_API_VERSION_PATCH(engine.m_handle->m_api_version) + PPM_API_VERSION_MAJOR(((SCAP_HANDLE_T*)engine.m_handle)->m_api_version), + PPM_API_VERSION_MINOR(((SCAP_HANDLE_T*)engine.m_handle)->m_api_version), + PPM_API_VERSION_PATCH(((SCAP_HANDLE_T*)engine.m_handle)->m_api_version) ); } // Set the API version from the first device // (for subsequent devices it's a no-op thanks to the check above) - engine.m_handle->m_api_version = api_version; + ((SCAP_HANDLE_T*)engine.m_handle)->m_api_version = api_version; // Check the schema version reported if (ioctl(dev->m_fd, PPM_IOCTL_GET_SCHEMA_VERSION, &schema_version) < 0) @@ -432,21 +432,21 @@ int32_t scap_kmod_init(scap_t *handle, scap_open_args *oargs) return scap_errprintf(handle->m_lasterr, err, "Kernel module does not support PPM_IOCTL_GET_SCHEMA_VERSION"); } // Make sure all devices report the same schema version - if (engine.m_handle->m_schema_version != 0 && engine.m_handle->m_schema_version != schema_version) + if (((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version != 0 && ((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version != schema_version) { return scap_errprintf(handle->m_lasterr, 0, "Schema version mismatch: device %s reports schema version %llu.%llu.%llu, expected %llu.%llu.%llu", filename, PPM_API_VERSION_MAJOR(schema_version), PPM_API_VERSION_MINOR(schema_version), PPM_API_VERSION_PATCH(schema_version), - PPM_API_VERSION_MAJOR(engine.m_handle->m_schema_version), - PPM_API_VERSION_MINOR(engine.m_handle->m_schema_version), - PPM_API_VERSION_PATCH(engine.m_handle->m_schema_version) + PPM_API_VERSION_MAJOR(((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version), + PPM_API_VERSION_MINOR(((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version), + PPM_API_VERSION_PATCH(((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version) ); } // Set the schema version from the first device // (for subsequent devices it's a no-op thanks to the check above) - engine.m_handle->m_schema_version = schema_version; + ((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version = schema_version; // // Map the ring buffer @@ -493,33 +493,33 @@ int32_t scap_kmod_init(scap_t *handle, scap_open_args *oargs) ++online_idx; } - + // Check that we parsed all online CPUs if(online_idx != devset->m_ndevs) { return scap_errprintf(handle->m_lasterr, 0, "mismatch, processors online after the 'for' loop: %d, '_SC_NPROCESSORS_ONLN' before the 'for' loop: %d", online_idx, devset->m_ndevs); } - + // Check that no CPUs were hotplugged during the for loop uint32_t final_ndevs = sysconf(_SC_NPROCESSORS_ONLN); if(final_ndevs == -1) { return scap_errprintf(handle->m_lasterr, errno, "cannot obtain the number of online CPUs from '_SC_NPROCESSORS_ONLN' to check against the previous value"); } - if (online_idx != final_ndevs) + if (online_idx != final_ndevs) { return scap_errprintf(handle->m_lasterr, 0, "mismatch, processors online after the 'for' loop: %d, '_SC_NPROCESSORS_ONLN' after the 'for' loop: %d", online_idx, final_ndevs); } /* Store interesting sc codes */ - memcpy(&engine.m_handle->curr_sc_set, &oargs->ppm_sc_of_interest, sizeof(interesting_ppm_sc_set)); + memcpy(&((SCAP_HANDLE_T*)engine.m_handle)->curr_sc_set, &oargs->ppm_sc_of_interest, sizeof(interesting_ppm_sc_set)); return SCAP_SUCCESS; } int32_t scap_kmod_close(struct scap_engine_handle engine) { - struct scap_device_set *devset = &engine.m_handle->m_dev_set; + struct scap_device_set *devset = &((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set; devset_free(devset); @@ -529,17 +529,17 @@ int32_t scap_kmod_close(struct scap_engine_handle engine) int32_t scap_kmod_next(struct scap_engine_handle engine, scap_evt **pevent, uint16_t *pdevid, uint32_t *pflags) { - return ringbuffer_next(&engine.m_handle->m_dev_set, pevent, pdevid, pflags); + return ringbuffer_next(&((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set, pevent, pdevid, pflags); } uint32_t scap_kmod_get_n_devs(struct scap_engine_handle engine) { - return engine.m_handle->m_dev_set.m_ndevs; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set.m_ndevs; } uint64_t scap_kmod_get_max_buf_used(struct scap_engine_handle engine) { - return ringbuffer_get_max_buf_used(&engine.m_handle->m_dev_set); + return ringbuffer_get_max_buf_used(&((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set); } // @@ -547,7 +547,7 @@ uint64_t scap_kmod_get_max_buf_used(struct scap_engine_handle engine) // int32_t scap_kmod_get_stats(struct scap_engine_handle engine, scap_stats* stats) { - struct scap_device_set *devset = &engine.m_handle->m_dev_set; + struct scap_device_set *devset = &((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set; uint32_t j; for(j = 0; j < devset->m_ndevs; j++) @@ -645,7 +645,7 @@ int32_t scap_kmod_stop_capture(struct scap_engine_handle engine) handle->capturing = false; /* This could happen if we fail to instantiate `m_devs` in the init method */ - struct scap_device_set *devset = &engine.m_handle->m_dev_set; + struct scap_device_set *devset = &((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set; if(devset->m_devs == NULL) { return SCAP_SUCCESS; @@ -681,7 +681,7 @@ int32_t scap_kmod_start_capture(struct scap_engine_handle engine) static int32_t scap_kmod_set_dropping_mode(struct scap_engine_handle engine, int request, uint32_t sampling_ratio) { - struct scap_device_set *devset = &engine.m_handle->m_dev_set; + struct scap_device_set *devset = &((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set; if(devset->m_ndevs) { ASSERT((request == PPM_IOCTL_ENABLE_DROPPING_MODE && @@ -696,7 +696,7 @@ static int32_t scap_kmod_set_dropping_mode(struct scap_engine_handle engine, int if(ioctl(devset->m_devs[0].m_fd, request, sampling_ratio)) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "%s, request %d for sampling ratio %u", + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "%s, request %d for sampling ratio %u", __FUNCTION__, request, sampling_ratio); } } @@ -715,13 +715,13 @@ int32_t scap_kmod_start_dropping_mode(struct scap_engine_handle engine, uint32_t int32_t scap_kmod_set_snaplen(struct scap_engine_handle engine, uint32_t snaplen) { - struct scap_device_set *devset = &engine.m_handle->m_dev_set; + struct scap_device_set *devset = &((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set; // // Tell the driver to change the snaplen // if(ioctl(devset->m_devs[0].m_fd, PPM_IOCTL_SET_SNAPLEN, snaplen)) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "scap_set_snaplen failed"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "scap_set_snaplen failed"); } uint32_t j; @@ -743,9 +743,9 @@ int32_t scap_kmod_set_snaplen(struct scap_engine_handle engine, uint32_t snaplen int32_t scap_kmod_handle_dropfailed(struct scap_engine_handle engine, bool enable) { int req = enable ? PPM_IOCTL_ENABLE_DROPFAILED : PPM_IOCTL_DISABLE_DROPFAILED; - if(ioctl(engine.m_handle->m_dev_set.m_devs[0].m_fd, req)) + if(ioctl(((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set.m_devs[0].m_fd, req)) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "scap_enable_dynamic_snaplen failed"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "scap_enable_dynamic_snaplen failed"); } return SCAP_SUCCESS; } @@ -756,18 +756,18 @@ int32_t scap_kmod_handle_dynamic_snaplen(struct scap_engine_handle engine, bool // Tell the driver to change the snaplen // int req = enable ? PPM_IOCTL_ENABLE_DYNAMIC_SNAPLEN : PPM_IOCTL_DISABLE_DYNAMIC_SNAPLEN; - if(ioctl(engine.m_handle->m_dev_set.m_devs[0].m_fd, req)) + if(ioctl(((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set.m_devs[0].m_fd, req)) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "scap_enable_dynamic_snaplen failed"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "scap_enable_dynamic_snaplen failed"); } return SCAP_SUCCESS; } int32_t scap_kmod_get_n_tracepoint_hit(struct scap_engine_handle engine, long* ret) { - if(ioctl(engine.m_handle->m_dev_set.m_devs[0].m_fd, PPM_IOCTL_GET_N_TRACEPOINT_HIT, ret)) + if(ioctl(((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set.m_devs[0].m_fd, PPM_IOCTL_GET_N_TRACEPOINT_HIT, ret)) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "scap_get_n_tracepoint_hit failed"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "scap_get_n_tracepoint_hit failed"); } return SCAP_SUCCESS; @@ -775,7 +775,7 @@ int32_t scap_kmod_get_n_tracepoint_hit(struct scap_engine_handle engine, long* r int32_t scap_kmod_set_fullcapture_port_range(struct scap_engine_handle engine, uint16_t range_start, uint16_t range_end) { - struct scap_device_set *devset = &engine.m_handle->m_dev_set; + struct scap_device_set *devset = &((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set; // // Encode the port range // @@ -786,7 +786,7 @@ int32_t scap_kmod_set_fullcapture_port_range(struct scap_engine_handle engine, u // if(ioctl(devset->m_devs[0].m_fd, PPM_IOCTL_SET_FULLCAPTURE_PORT_RANGE, arg)) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "scap_set_fullcapture_port_range failed"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "scap_set_fullcapture_port_range failed"); } uint32_t j; @@ -808,13 +808,13 @@ int32_t scap_kmod_set_fullcapture_port_range(struct scap_engine_handle engine, u int32_t scap_kmod_set_statsd_port(struct scap_engine_handle engine, const uint16_t port) { - struct scap_device_set *devset = &engine.m_handle->m_dev_set; + struct scap_device_set *devset = &((SCAP_HANDLE_T*)engine.m_handle)->m_dev_set; // // Beam the value down to the module // if(ioctl(devset->m_devs[0].m_fd, PPM_IOCTL_SET_STATSD_PORT, port)) { - return scap_errprintf(engine.m_handle->m_lasterr, + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "scap_set_statsd_port: ioctl failed"); } @@ -953,12 +953,12 @@ int32_t scap_kmod_getpid_global(struct scap_engine_handle engine, int64_t* pid, uint64_t scap_kmod_get_api_version(struct scap_engine_handle engine) { - return engine.m_handle->m_api_version; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_api_version; } uint64_t scap_kmod_get_schema_version(struct scap_engine_handle engine) { - return engine.m_handle->m_schema_version; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version; } const struct scap_linux_vtable scap_kmod_linux_vtable = { @@ -972,7 +972,7 @@ struct scap_vtable scap_kmod_engine = { .name = KMOD_ENGINE, .savefile_ops = NULL, - .alloc_handle = alloc_handle, + .alloc_handle = (void* (*)(scap_t*, char*))alloc_handle, .init = scap_kmod_init, .free_handle = free_handle, .close = scap_kmod_close, diff --git a/userspace/libscap/engine/modern_bpf/scap_modern_bpf.c b/userspace/libscap/engine/modern_bpf/scap_modern_bpf.c index 33297052a8d..716af33363f 100644 --- a/userspace/libscap/engine/modern_bpf/scap_modern_bpf.c +++ b/userspace/libscap/engine/modern_bpf/scap_modern_bpf.c @@ -60,13 +60,13 @@ static int32_t scap_modern_bpf__next(struct scap_engine_handle engine, scap_evt* if((*pevent) == NULL) { /* The first time we sleep 500 us, if we have consecutive timeouts we can reach also 30 ms. */ - usleep(engine.m_handle->m_retry_us); - engine.m_handle->m_retry_us = MIN(engine.m_handle->m_retry_us * 2, BUFFER_EMPTY_WAIT_TIME_US_MAX); + usleep(((SCAP_HANDLE_T*)engine.m_handle)->m_retry_us); + ((SCAP_HANDLE_T*)engine.m_handle)->m_retry_us = MIN(((SCAP_HANDLE_T*)engine.m_handle)->m_retry_us * 2, BUFFER_EMPTY_WAIT_TIME_US_MAX); return SCAP_TIMEOUT; } else { - engine.m_handle->m_retry_us = BUFFER_EMPTY_WAIT_TIME_US_START; + ((SCAP_HANDLE_T*)engine.m_handle)->m_retry_us = BUFFER_EMPTY_WAIT_TIME_US_START; } *pflags = 0; return SCAP_SUCCESS; @@ -174,25 +174,25 @@ static int32_t calibrate_socket_file_ops(struct scap_engine_handle engine) */ pid_t scap_tid = syscall(__NR_gettid); pman_set_scap_tid(scap_tid); - + /* We just need to enable the socket syscall for the socket calibration */ - engine.m_handle->curr_sc_set.ppm_sc[PPM_SC_SOCKET] = 1; + ((SCAP_HANDLE_T*)engine.m_handle)->curr_sc_set.ppm_sc[PPM_SC_SOCKET] = 1; if(scap_modern_bpf__start_capture(engine) != SCAP_SUCCESS) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "unable to start the capture for the socket calibration"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "unable to start the capture for the socket calibration"); } int fd = socket(AF_INET, SOCK_DGRAM, 0); if(fd == -1) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "unable to create a socket for the calibration"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "unable to create a socket for the calibration"); } close(fd); /* We need to stop the capture */ if(scap_modern_bpf__stop_capture(engine) != SCAP_SUCCESS) { - return scap_errprintf(engine.m_handle->m_lasterr, errno, "unable to stop the capture after the calibration"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, errno, "unable to stop the capture after the calibration"); } /* We need to read the socket event from the buffer */ @@ -230,7 +230,7 @@ static int32_t calibrate_socket_file_ops(struct scap_engine_handle engine) if(!found) { - return scap_errprintf(engine.m_handle->m_lasterr, 0, "unable to find the socket event for the calibration in the ringbuffers"); + return scap_errprintf(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, 0, "unable to find the socket event for the calibration in the ringbuffers"); } return SCAP_SUCCESS; } @@ -268,7 +268,7 @@ int32_t scap_modern_bpf__init(scap_t* handle, scap_open_args* oargs) } /* Set an initial sleep time in case of timeouts. */ - engine.m_handle->m_retry_us = BUFFER_EMPTY_WAIT_TIME_US_START; + ((SCAP_HANDLE_T*)engine.m_handle)->m_retry_us = BUFFER_EMPTY_WAIT_TIME_US_START; /* Load and attach */ ret = pman_open_probe(); @@ -297,15 +297,15 @@ int32_t scap_modern_bpf__init(scap_t* handle, scap_open_args* oargs) } /* Store interesting sc codes */ - memcpy(&engine.m_handle->curr_sc_set, &oargs->ppm_sc_of_interest, sizeof(interesting_ppm_sc_set)); + memcpy(&((SCAP_HANDLE_T*)engine.m_handle)->curr_sc_set, &oargs->ppm_sc_of_interest, sizeof(interesting_ppm_sc_set)); - engine.m_handle->m_api_version = pman_get_probe_api_ver(); - engine.m_handle->m_schema_version = pman_get_probe_schema_ver(); + ((SCAP_HANDLE_T*)engine.m_handle)->m_api_version = pman_get_probe_api_ver(); + ((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version = pman_get_probe_schema_ver(); - engine.m_handle->m_flags = 0; + ((SCAP_HANDLE_T*)engine.m_handle)->m_flags = 0; if(scap_get_bpf_stats_enabled()) { - engine.m_handle->m_flags |= ENGINE_FLAG_BPF_STATS_ENABLED; + ((SCAP_HANDLE_T*)engine.m_handle)->m_flags |= ENGINE_FLAG_BPF_STATS_ENABLED; } return SCAP_SUCCESS; @@ -313,7 +313,7 @@ int32_t scap_modern_bpf__init(scap_t* handle, scap_open_args* oargs) static uint64_t scap_modern_bpf__get_flags(struct scap_engine_handle engine) { - return engine.m_handle->m_flags; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_flags; } int32_t scap_modern_bpf__close(struct scap_engine_handle engine) @@ -358,19 +358,19 @@ int32_t scap_modern_bpf__get_n_tracepoint_hit(struct scap_engine_handle engine, uint64_t scap_modern_bpf__get_api_version(struct scap_engine_handle engine) { - return engine.m_handle->m_api_version; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_api_version; } uint64_t scap_modern_bpf__get_schema_version(struct scap_engine_handle engine) { - return engine.m_handle->m_schema_version; + return ((SCAP_HANDLE_T*)engine.m_handle)->m_schema_version; } struct scap_vtable scap_modern_bpf_engine = { .name = MODERN_BPF_ENGINE, .savefile_ops = NULL, - .alloc_handle = scap_modern_bpf__alloc_engine, + .alloc_handle = (void* (*)(scap_t*, char*))scap_modern_bpf__alloc_engine, .init = scap_modern_bpf__init, .get_flags = scap_modern_bpf__get_flags, .free_handle = scap_modern_bpf__free_engine, diff --git a/userspace/libscap/engine/nodriver/nodriver.c b/userspace/libscap/engine/nodriver/nodriver.c index cd130ac55c4..74275777c86 100644 --- a/userspace/libscap/engine/nodriver/nodriver.c +++ b/userspace/libscap/engine/nodriver/nodriver.c @@ -65,7 +65,7 @@ const struct scap_vtable scap_nodriver_engine = { .name = NODRIVER_ENGINE, .savefile_ops = NULL, - .alloc_handle = alloc_handle, + .alloc_handle = (void* (*)(scap_t*, char*))alloc_handle, .init = init, .free_handle = noop_free_handle, .close = noop_close_engine, diff --git a/userspace/libscap/engine/noop/noop.c b/userspace/libscap/engine/noop/noop.c index eeb20a2d53f..fc091056f75 100644 --- a/userspace/libscap/engine/noop/noop.c +++ b/userspace/libscap/engine/noop/noop.c @@ -79,7 +79,7 @@ int32_t noop_configure(struct scap_engine_handle engine, enum scap_setting setti { return SCAP_SUCCESS; } - return unimplemented_op(engine.m_handle->m_lasterr, SCAP_LASTERR_SIZE); + return unimplemented_op(((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr, SCAP_LASTERR_SIZE); } int32_t noop_get_stats(struct scap_engine_handle engine, scap_stats* stats) @@ -113,7 +113,7 @@ const struct scap_vtable scap_noop_engine = { .name = "noop", .savefile_ops = NULL, - .alloc_handle = noop_alloc_handle, + .alloc_handle = (void* (*)(scap_t*, char*))noop_alloc_handle, .init = NULL, .free_handle = noop_free_handle, .close = noop_close_engine, diff --git a/userspace/libscap/engine/savefile/scap_savefile.c b/userspace/libscap/engine/savefile/scap_savefile.c index 76cbce540a5..ccb55610957 100644 --- a/userspace/libscap/engine/savefile/scap_savefile.c +++ b/userspace/libscap/engine/savefile/scap_savefile.c @@ -2059,13 +2059,13 @@ static int32_t next(struct scap_engine_handle engine, scap_evt **pevent, uint16_ uint64_t scap_savefile_ftell(struct scap_engine_handle engine) { - scap_reader_t* reader = engine.m_handle->m_reader; + scap_reader_t* reader = ((SCAP_HANDLE_T*)engine.m_handle)->m_reader; return reader->tell(reader); } void scap_savefile_fseek(struct scap_engine_handle engine, uint64_t off) { - scap_reader_t* reader = engine.m_handle->m_reader; + scap_reader_t* reader = ((SCAP_HANDLE_T*)engine.m_handle)->m_reader; reader->seek(reader, off, SEEK_SET); } @@ -2276,7 +2276,7 @@ static int32_t scap_savefile_restart_capture(scap_t* handle) static int64_t get_readfile_offset(struct scap_engine_handle engine) { - return engine.m_handle->m_reader->offset(engine.m_handle->m_reader); + return ((SCAP_HANDLE_T*)engine.m_handle)->m_reader->offset(((SCAP_HANDLE_T*)engine.m_handle)->m_reader); } static struct scap_savefile_vtable savefile_ops = { @@ -2291,7 +2291,7 @@ struct scap_vtable scap_savefile_engine = { .name = SAVEFILE_ENGINE, .savefile_ops = &savefile_ops, - .alloc_handle = alloc_handle, + .alloc_handle = (void* (*)(scap_t*, char*))alloc_handle, .init = init, .free_handle = free_handle, .close = scap_savefile_close, diff --git a/userspace/libscap/engine/source_plugin/source_plugin.c b/userspace/libscap/engine/source_plugin/source_plugin.c index 7e15857de5d..6969ad1bf7b 100644 --- a/userspace/libscap/engine/source_plugin/source_plugin.c +++ b/userspace/libscap/engine/source_plugin/source_plugin.c @@ -159,7 +159,7 @@ static int close_engine(struct scap_engine_handle engine) static int32_t next(struct scap_engine_handle engine, scap_evt** pevent, uint16_t* pdevid, uint32_t* pflags) { struct source_plugin_engine *handle = engine.m_handle; - char *lasterr = engine.m_handle->m_lasterr; + char *lasterr = ((SCAP_HANDLE_T*)engine.m_handle)->m_lasterr; /* we have to read a new batch */ if(handle->m_input_plugin_batch_idx >= handle->m_input_plugin_batch_nevts) @@ -252,7 +252,7 @@ static int32_t next(struct scap_engine_handle engine, scap_evt** pevent, uint16_ // plugin events have no thread associated evt->tid = (uint64_t) -1; } - + // automatically set timestamp if none was specified if(evt->ts == UINT64_MAX) { @@ -305,7 +305,7 @@ const struct scap_vtable scap_source_plugin_engine = { .name = SOURCE_PLUGIN_ENGINE, .savefile_ops = NULL, - .alloc_handle = alloc_handle, + .alloc_handle = (void* (*)(scap_t*, char*))alloc_handle, .init = init, .free_handle = noop_free_handle, .close = close_engine, diff --git a/userspace/libscap/engine/test_input/test_input.c b/userspace/libscap/engine/test_input/test_input.c index 55d6fce3657..371d7ccdb46 100644 --- a/userspace/libscap/engine/test_input/test_input.c +++ b/userspace/libscap/engine/test_input/test_input.c @@ -88,7 +88,7 @@ const struct scap_vtable scap_test_input_engine = { .name = TEST_INPUT_ENGINE, .savefile_ops = NULL, - .alloc_handle = alloc_handle, + .alloc_handle = (void* (*)(scap_t*, char*))alloc_handle, .init = init, .free_handle = noop_free_handle, .close = noop_close_engine, diff --git a/userspace/libscap/engine_handle.h b/userspace/libscap/engine_handle.h index b010150efe3..98d2bbb2448 100644 --- a/userspace/libscap/engine_handle.h +++ b/userspace/libscap/engine_handle.h @@ -18,10 +18,6 @@ limitations under the License. #pragma once -#ifndef SCAP_HANDLE_T -#error "You need to define SCAP_HANDLE_T to a concrete type before including engine_handle.h" -#endif - #ifdef __cplusplus extern "C" { #endif @@ -29,7 +25,7 @@ extern "C" { // this is passed by value everywhere so keep it small // it only contains a pointer to a struct containing the engine-specific bits struct scap_engine_handle { - SCAP_HANDLE_T* m_handle; + void* m_handle; }; #ifdef __cplusplus diff --git a/userspace/libscap/scap_vtable.h b/userspace/libscap/scap_vtable.h index c69373222f0..cbe1d0d0ab8 100644 --- a/userspace/libscap/scap_vtable.h +++ b/userspace/libscap/scap_vtable.h @@ -131,7 +131,7 @@ struct scap_vtable { * in the engine handle for easier access * @return pointer to the newly allocated handle or NULL */ - SCAP_HANDLE_T* (*alloc_handle)(scap_t* main_handle, char *lasterr_ptr); + void* (*alloc_handle)(scap_t* main_handle, char* lasterr_ptr); /** * @brief perform engine-specific initialization