On Tue, Apr 04, 2023 at 01:07:27PM -0700, Tyler Retzlaff wrote: > Windows does not support versioned symbols. Fortunately Windows also > doesn't have an exported stable ABI. > > Export rte_tel_data_add_array_int -> rte_tel_data_add_array_int_24 > and rte_tel_data_add_dict_int -> rte_tel_data_add_dict_int_v24 > functions. > > Windows does have a way to achieve similar versioning for symbols but it > is not a simple #define so it will be done as a work package later. > > Signed-off-by: Tyler Retzlaff <roret...@linux.microsoft.com>
Does this require a change in telemetry itself? Can it be done via the header file with the versioning macros in it, so it would apply to any other versioned functions we have in DPDK? /Bruce > --- > lib/telemetry/telemetry_data.c | 16 ++++++++++++++++ > 1 file changed, 16 insertions(+) > > diff --git a/lib/telemetry/telemetry_data.c b/lib/telemetry/telemetry_data.c > index 2bac2de..284c16e 100644 > --- a/lib/telemetry/telemetry_data.c > +++ b/lib/telemetry/telemetry_data.c > @@ -82,8 +82,16 @@ > /* mark the v23 function as the older version, and v24 as the default > version */ > VERSION_SYMBOL(rte_tel_data_add_array_int, _v23, 23); > BIND_DEFAULT_SYMBOL(rte_tel_data_add_array_int, _v24, 24); > +#ifndef RTE_TOOLCHAIN_MSVC > MAP_STATIC_SYMBOL(int rte_tel_data_add_array_int(struct rte_tel_data *d, > int64_t x), rte_tel_data_add_array_int_v24); > +#else > +int > +rte_tel_data_add_array_int(struct rte_tel_data *d, int64_t x) > +{ > + return rte_tel_data_add_array_int_v24(d, x); > +} > +#endif > > int > rte_tel_data_add_array_uint(struct rte_tel_data *d, uint64_t x) > @@ -220,8 +228,16 @@ > /* mark the v23 function as the older version, and v24 as the default > version */ > VERSION_SYMBOL(rte_tel_data_add_dict_int, _v23, 23); > BIND_DEFAULT_SYMBOL(rte_tel_data_add_dict_int, _v24, 24); > +#ifndef RTE_TOOLCHAIN_MSVC > MAP_STATIC_SYMBOL(int rte_tel_data_add_dict_int(struct rte_tel_data *d, > const char *name, int64_t val), rte_tel_data_add_dict_int_v24); > +#else > +int > +rte_tel_data_add_dict_int(struct rte_tel_data *d, const char *name, int64_t > val) > +{ > + return rte_tel_data_add_dict_int_v24(d, name, val); > +} > +#endif > > int > rte_tel_data_add_dict_uint(struct rte_tel_data *d, > -- > 1.8.3.1 >