* [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
@ 2014-07-24 7:59 Matthew Hall
2014-07-24 15:43 ` Niraj Sharma (nirajsha)
2014-07-24 22:55 ` Antti Kantee
0 siblings, 2 replies; 9+ messages in thread
From: Matthew Hall @ 2014-07-24 7:59 UTC (permalink / raw)
To: dev
Hello,
I ran into some weird symbol conflicts between system netinet/in.h and DPDK
rte_ip.h. They have a lot of duplicated definitions for stuff like IPPROTO_IP
and so on. This breaks when you want to use inet_pton from arpa/inet.h,
because it includes netinet/in.h to define struct in_addr.
Thus with all the conflicts it's impossible to use a DPDK IP struct instead of
all the system's sockaddr stuff, to store a value from the system copy of
inet_pton. This would be a common operation if, for example, you want to
configure all the IP addresses on your box from a JSON file, which is what I
was doing.
The DPDK kludged around it internally by using a file called
cmdline_parse_ipaddr.c with private copies of these functions. But it in my
opinion very unwisely marked all of the functions as static except for
cmdline_parse_ipaddr, which only works on the DPDK's proprietary argument
handling, and not with anything the user might have which is a different
format.
So, it would be a big help for users if the macros in librte_net files would
check if the symbols already existed, or if they had subheader files available
to grab only non conflicting symbols, or if they would make a proper .h and
factor all the inet_pton and inet_ntop inside the cmdline lib into a place
where users can access them. It would also be a help if they had a less ugly
equivalent to struct sockaddr, which let you work with IP addresses a bit more
easily, such as something like this:
struct ip4_addr {
uint32_t addr;
};
typedef struct ip4_addr ip4_addr;
struct ip6_addr {
uint8_t addr[16];
};
typedef struct ip6_addr ip6_addr;
struct ip_addr {
uint8_t family;
uint8_t prefix;
union {
struct ip4_addr ipv4;
struct ip6_addr ipv6;
};
};
I had to create a bunch of duplicate code to handle it in my project, since
the DPDK marked its copies of all these functions as "secret" and didn't make
a .h for them. If any of it is useful I am happy to donate it, although I
don't think I've got quite enough experience with this specifc part of the
DPDK to code it up all by myself.
Thanks,
Matthew.
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
2014-07-24 7:59 [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h Matthew Hall
@ 2014-07-24 15:43 ` Niraj Sharma (nirajsha)
2014-07-24 22:55 ` Antti Kantee
1 sibling, 0 replies; 9+ messages in thread
From: Niraj Sharma (nirajsha) @ 2014-07-24 15:43 UTC (permalink / raw)
To: Matthew Hall, dev
I also noticed this problem. It is a serious one. I would like it solved.
-- Niraj Sharma
Principal Eng.
Cisco System, Inc.
On 7/24/14 12:59 AM, "Matthew Hall" <mhall@mhcomputing.net> wrote:
>Hello,
>
>I ran into some weird symbol conflicts between system netinet/in.h and
>DPDK
>rte_ip.h. They have a lot of duplicated definitions for stuff like
>IPPROTO_IP
>and so on. This breaks when you want to use inet_pton from arpa/inet.h,
>because it includes netinet/in.h to define struct in_addr.
>
>Thus with all the conflicts it's impossible to use a DPDK IP struct
>instead of
>all the system's sockaddr stuff, to store a value from the system copy of
>inet_pton. This would be a common operation if, for example, you want to
>configure all the IP addresses on your box from a JSON file, which is
>what I
>was doing.
>
>The DPDK kludged around it internally by using a file called
>cmdline_parse_ipaddr.c with private copies of these functions. But it in
>my
>opinion very unwisely marked all of the functions as static except for
>cmdline_parse_ipaddr, which only works on the DPDK's proprietary argument
>handling, and not with anything the user might have which is a different
>format.
>
>So, it would be a big help for users if the macros in librte_net files
>would
>check if the symbols already existed, or if they had subheader files
>available
>to grab only non conflicting symbols, or if they would make a proper .h
>and
>factor all the inet_pton and inet_ntop inside the cmdline lib into a
>place
>where users can access them. It would also be a help if they had a less
>ugly
>equivalent to struct sockaddr, which let you work with IP addresses a bit
>more
>easily, such as something like this:
>
>struct ip4_addr {
> uint32_t addr;
>};
>
>typedef struct ip4_addr ip4_addr;
>
>struct ip6_addr {
> uint8_t addr[16];
>};
>
>typedef struct ip6_addr ip6_addr;
>
>struct ip_addr {
> uint8_t family;
> uint8_t prefix;
> union {
> struct ip4_addr ipv4;
> struct ip6_addr ipv6;
> };
>};
>
>I had to create a bunch of duplicate code to handle it in my project,
>since
>the DPDK marked its copies of all these functions as "secret" and didn't
>make
>a .h for them. If any of it is useful I am happy to donate it, although I
>don't think I've got quite enough experience with this specifc part of
>the
>DPDK to code it up all by myself.
>
>Thanks,
>Matthew.
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
2014-07-24 7:59 [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h Matthew Hall
2014-07-24 15:43 ` Niraj Sharma (nirajsha)
@ 2014-07-24 22:55 ` Antti Kantee
2014-07-24 23:03 ` Matthew Hall
` (2 more replies)
1 sibling, 3 replies; 9+ messages in thread
From: Antti Kantee @ 2014-07-24 22:55 UTC (permalink / raw)
To: Matthew Hall, dev
On 24/07/14 07:59, Matthew Hall wrote:
> Hello,
>
> I ran into some weird symbol conflicts between system netinet/in.h and DPDK
> rte_ip.h. They have a lot of duplicated definitions for stuff like IPPROTO_IP
> and so on. This breaks when you want to use inet_pton from arpa/inet.h,
> because it includes netinet/in.h to define struct in_addr.
I would namespace the definitions in DPDK, i.e. make them
DPDK_IPPROTO_FOO etc.
> Thus with all the conflicts it's impossible to use a DPDK IP struct instead of
> all the system's sockaddr stuff, to store a value from the system copy of
> inet_pton. This would be a common operation if, for example, you want to
> configure all the IP addresses on your box from a JSON file, which is what I
> was doing.
>
> The DPDK kludged around it internally by using a file called
> cmdline_parse_ipaddr.c with private copies of these functions. But it in my
> opinion very unwisely marked all of the functions as static except for
> cmdline_parse_ipaddr, which only works on the DPDK's proprietary argument
> handling, and not with anything the user might have which is a different
> format.
In my experience from years of fighting with more or less this exact
same problem -- the fight is now thankfully over but the scars remain --
you either want to expose a complete set of types and provide support
for everything, or you want to expose nothing. Approaches where you use
cute definitions and reuse some host routines is like asking for an
audience with Tyranthraxus when armed with a kitten. It's that doubly
so if you don't have to and do it anyway.
> So, it would be a big help for users if the macros in librte_net files would
> check if the symbols already existed, or if they had subheader files available
> to grab only non conflicting symbols, or if they would make a proper .h and
> factor all the inet_pton and inet_ntop inside the cmdline lib into a place
> where users can access them. It would also be a help if they had a less ugly
> equivalent to struct sockaddr, which let you work with IP addresses a bit more
> easily, such as something like this:
Again, I recommend steering away from any tightrope approaches that
"know" which types are non-conflicting, or pick out half-and-half from
the host and IP stack. "Do, or do not, there is no half-and-half"
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
2014-07-24 22:55 ` Antti Kantee
@ 2014-07-24 23:03 ` Matthew Hall
2014-07-25 1:12 ` Wu, Jingjing
2014-07-25 10:43 ` Thomas Monjalon
2 siblings, 0 replies; 9+ messages in thread
From: Matthew Hall @ 2014-07-24 23:03 UTC (permalink / raw)
To: Antti Kantee; +Cc: dev
On Thu, Jul 24, 2014 at 10:55:59PM +0000, Antti Kantee wrote:
> In my experience from years of fighting with more or less this exact same
> problem -- the fight is now thankfully over but the scars remain -- you
> either want to expose a complete set of types and provide support for
> everything, or you want to expose nothing.
I don't have a problem with this approach. Implementing it would require the
DPDK to create user accessible functions for creating MAC addresses, IPs,
CIDRs, and TCP / UDP port numbers. Many of the things required are hiding
inside of *cmdline* code where it's impossible for anybody to access them.
Matthew.
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
2014-07-24 22:55 ` Antti Kantee
2014-07-24 23:03 ` Matthew Hall
@ 2014-07-25 1:12 ` Wu, Jingjing
2014-07-25 4:56 ` Matthew Hall
2014-07-25 10:43 ` Thomas Monjalon
2 siblings, 1 reply; 9+ messages in thread
From: Wu, Jingjing @ 2014-07-25 1:12 UTC (permalink / raw)
To: Antti Kantee, Matthew Hall, dev
Hello,
We also notice these conflicts, we just planned to fix it in our new feature development. The proposal is like:
#ifndef _NETINET_IN_H
#ifndef _NETINET_IN_H_
#define IPPROTO_IP 0
... ...
#define IPPROTO_MAX 256
#endif
#endif
Do you think it is a good idea?
> -----Original Message-----
> From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Antti Kantee
> Sent: Friday, July 25, 2014 6:56 AM
> To: Matthew Hall; dev@dpdk.org
> Subject: Re: [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
>
> On 24/07/14 07:59, Matthew Hall wrote:
> > Hello,
> >
> > I ran into some weird symbol conflicts between system netinet/in.h and DPDK
> > rte_ip.h. They have a lot of duplicated definitions for stuff like IPPROTO_IP
> > and so on. This breaks when you want to use inet_pton from arpa/inet.h,
> > because it includes netinet/in.h to define struct in_addr.
>
> I would namespace the definitions in DPDK, i.e. make them
> DPDK_IPPROTO_FOO etc.
>
> > Thus with all the conflicts it's impossible to use a DPDK IP struct instead of
> > all the system's sockaddr stuff, to store a value from the system copy of
> > inet_pton. This would be a common operation if, for example, you want to
> > configure all the IP addresses on your box from a JSON file, which is what I
> > was doing.
> >
> > The DPDK kludged around it internally by using a file called
> > cmdline_parse_ipaddr.c with private copies of these functions. But it in my
> > opinion very unwisely marked all of the functions as static except for
> > cmdline_parse_ipaddr, which only works on the DPDK's proprietary argument
> > handling, and not with anything the user might have which is a different
> > format.
>
> In my experience from years of fighting with more or less this exact
> same problem -- the fight is now thankfully over but the scars remain --
> you either want to expose a complete set of types and provide support
> for everything, or you want to expose nothing. Approaches where you use
> cute definitions and reuse some host routines is like asking for an
> audience with Tyranthraxus when armed with a kitten. It's that doubly
> so if you don't have to and do it anyway.
>
> > So, it would be a big help for users if the macros in librte_net files would
> > check if the symbols already existed, or if they had subheader files available
> > to grab only non conflicting symbols, or if they would make a proper .h and
> > factor all the inet_pton and inet_ntop inside the cmdline lib into a place
> > where users can access them. It would also be a help if they had a less ugly
> > equivalent to struct sockaddr, which let you work with IP addresses a bit more
> > easily, such as something like this:
>
> Again, I recommend steering away from any tightrope approaches that
> "know" which types are non-conflicting, or pick out half-and-half from
> the host and IP stack. "Do, or do not, there is no half-and-half"
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
2014-07-25 1:12 ` Wu, Jingjing
@ 2014-07-25 4:56 ` Matthew Hall
2014-07-25 10:33 ` Ananyev, Konstantin
0 siblings, 1 reply; 9+ messages in thread
From: Matthew Hall @ 2014-07-25 4:56 UTC (permalink / raw)
To: Wu, Jingjing, Antti Kantee, dev
I don't know if it will work right on both Linux and BSD and/or if they also 100% agree with the libc / glibc values compiled into the system's .so files. That's the risk that you run if you don't have more complete support in the DPDK itself for these features.
--
Sent from my mobile device.
On July 24, 2014 6:12:18 PM PDT, "Wu, Jingjing" <jingjing.wu@intel.com> wrote:
>Hello,
>
>We also notice these conflicts, we just planned to fix it in our new
>feature development. The proposal is like:
>
>#ifndef _NETINET_IN_H
>#ifndef _NETINET_IN_H_
>
>#define IPPROTO_IP 0
> ... ...
>#define IPPROTO_MAX 256
>
>#endif
>#endif
>
>Do you think it is a good idea?
>
>> -----Original Message-----
>> From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Antti Kantee
>> Sent: Friday, July 25, 2014 6:56 AM
>> To: Matthew Hall; dev@dpdk.org
>> Subject: Re: [dpdk-dev] symbol conflicts between netinet/in.h,
>arpa/inet.h, and rte_ip.h
>>
>> On 24/07/14 07:59, Matthew Hall wrote:
>> > Hello,
>> >
>> > I ran into some weird symbol conflicts between system netinet/in.h
>and DPDK
>> > rte_ip.h. They have a lot of duplicated definitions for stuff like
>IPPROTO_IP
>> > and so on. This breaks when you want to use inet_pton from
>arpa/inet.h,
>> > because it includes netinet/in.h to define struct in_addr.
>>
>> I would namespace the definitions in DPDK, i.e. make them
>> DPDK_IPPROTO_FOO etc.
>>
>> > Thus with all the conflicts it's impossible to use a DPDK IP struct
>instead of
>> > all the system's sockaddr stuff, to store a value from the system
>copy of
>> > inet_pton. This would be a common operation if, for example, you
>want to
>> > configure all the IP addresses on your box from a JSON file, which
>is what I
>> > was doing.
>> >
>> > The DPDK kludged around it internally by using a file called
>> > cmdline_parse_ipaddr.c with private copies of these functions. But
>it in my
>> > opinion very unwisely marked all of the functions as static except
>for
>> > cmdline_parse_ipaddr, which only works on the DPDK's proprietary
>argument
>> > handling, and not with anything the user might have which is a
>different
>> > format.
>>
>> In my experience from years of fighting with more or less this exact
>> same problem -- the fight is now thankfully over but the scars remain
>--
>> you either want to expose a complete set of types and provide support
>> for everything, or you want to expose nothing. Approaches where you
>use
>> cute definitions and reuse some host routines is like asking for an
>> audience with Tyranthraxus when armed with a kitten. It's that
>doubly
>> so if you don't have to and do it anyway.
>>
>> > So, it would be a big help for users if the macros in librte_net
>files would
>> > check if the symbols already existed, or if they had subheader
>files available
>> > to grab only non conflicting symbols, or if they would make a
>proper .h and
>> > factor all the inet_pton and inet_ntop inside the cmdline lib into
>a place
>> > where users can access them. It would also be a help if they had a
>less ugly
>> > equivalent to struct sockaddr, which let you work with IP addresses
>a bit more
>> > easily, such as something like this:
>>
>> Again, I recommend steering away from any tightrope approaches that
>> "know" which types are non-conflicting, or pick out half-and-half
>from
>> the host and IP stack. "Do, or do not, there is no half-and-half"
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
2014-07-25 4:56 ` Matthew Hall
@ 2014-07-25 10:33 ` Ananyev, Konstantin
0 siblings, 0 replies; 9+ messages in thread
From: Ananyev, Konstantin @ 2014-07-25 10:33 UTC (permalink / raw)
To: Matthew Hall, Wu, Jingjing, Antti Kantee, dev
>
> I don't know if it will work right on both Linux and BSD and/or if they also 100% agree with the libc / glibc values compiled into the
> system's .so files. That's the risk that you run if you don't have more complete support in the DPDK itself for these features.
Looking at linux and freebsd netinet/in.h files - I think it should work.
But I suppose we can test it on both freebsd and linux before submitting a patch.
> --
> Sent from my mobile device.
>
> On July 24, 2014 6:12:18 PM PDT, "Wu, Jingjing" <jingjing.wu@intel.com> wrote:
> >Hello,
> >
> >We also notice these conflicts, we just planned to fix it in our new
> >feature development. The proposal is like:
> >
> >#ifndef _NETINET_IN_H
> >#ifndef _NETINET_IN_H_
> >
> >#define IPPROTO_IP 0
> > ... ...
> >#define IPPROTO_MAX 256
> >
> >#endif
> >#endif
> >
> >Do you think it is a good idea?
> >
> >> -----Original Message-----
> >> From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Antti Kantee
> >> Sent: Friday, July 25, 2014 6:56 AM
> >> To: Matthew Hall; dev@dpdk.org
> >> Subject: Re: [dpdk-dev] symbol conflicts between netinet/in.h,
> >arpa/inet.h, and rte_ip.h
> >>
> >> On 24/07/14 07:59, Matthew Hall wrote:
> >> > Hello,
> >> >
> >> > I ran into some weird symbol conflicts between system netinet/in.h
> >and DPDK
> >> > rte_ip.h. They have a lot of duplicated definitions for stuff like
> >IPPROTO_IP
> >> > and so on. This breaks when you want to use inet_pton from
> >arpa/inet.h,
> >> > because it includes netinet/in.h to define struct in_addr.
> >>
> >> I would namespace the definitions in DPDK, i.e. make them
> >> DPDK_IPPROTO_FOO etc.
> >>
> >> > Thus with all the conflicts it's impossible to use a DPDK IP struct
> >instead of
> >> > all the system's sockaddr stuff, to store a value from the system
> >copy of
> >> > inet_pton. This would be a common operation if, for example, you
> >want to
> >> > configure all the IP addresses on your box from a JSON file, which
> >is what I
> >> > was doing.
> >> >
> >> > The DPDK kludged around it internally by using a file called
> >> > cmdline_parse_ipaddr.c with private copies of these functions. But
> >it in my
> >> > opinion very unwisely marked all of the functions as static except
> >for
> >> > cmdline_parse_ipaddr, which only works on the DPDK's proprietary
> >argument
> >> > handling, and not with anything the user might have which is a
> >different
> >> > format.
> >>
> >> In my experience from years of fighting with more or less this exact
> >> same problem -- the fight is now thankfully over but the scars remain
> >--
> >> you either want to expose a complete set of types and provide support
> >> for everything, or you want to expose nothing. Approaches where you
> >use
> >> cute definitions and reuse some host routines is like asking for an
> >> audience with Tyranthraxus when armed with a kitten. It's that
> >doubly
> >> so if you don't have to and do it anyway.
> >>
> >> > So, it would be a big help for users if the macros in librte_net
> >files would
> >> > check if the symbols already existed, or if they had subheader
> >files available
> >> > to grab only non conflicting symbols, or if they would make a
> >proper .h and
> >> > factor all the inet_pton and inet_ntop inside the cmdline lib into
> >a place
> >> > where users can access them. It would also be a help if they had a
> >less ugly
> >> > equivalent to struct sockaddr, which let you work with IP addresses
> >a bit more
> >> > easily, such as something like this:
> >>
> >> Again, I recommend steering away from any tightrope approaches that
> >> "know" which types are non-conflicting, or pick out half-and-half
> >from
> >> the host and IP stack. "Do, or do not, there is no half-and-half"
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
2014-07-24 22:55 ` Antti Kantee
2014-07-24 23:03 ` Matthew Hall
2014-07-25 1:12 ` Wu, Jingjing
@ 2014-07-25 10:43 ` Thomas Monjalon
2014-07-25 14:40 ` Antti Kantee
2 siblings, 1 reply; 9+ messages in thread
From: Thomas Monjalon @ 2014-07-25 10:43 UTC (permalink / raw)
To: dev
Hi all,
2014-07-24 22:55, Antti Kantee:
> On 24/07/14 07:59, Matthew Hall wrote:
> > I ran into some weird symbol conflicts between system netinet/in.h and DPDK
> > rte_ip.h. They have a lot of duplicated definitions for stuff like IPPROTO_IP
> > and so on. This breaks when you want to use inet_pton from arpa/inet.h,
> > because it includes netinet/in.h to define struct in_addr.
[...]
> Again, I recommend steering away from any tightrope approaches that
> "know" which types are non-conflicting, or pick out half-and-half from
> the host and IP stack. "Do, or do not, there is no half-and-half"
The general problem here is that DPDK is conflicting with libc.
So the obvious question would be: "why DPDK needs to redefine libc stuff"?
I don't see any obvious answer since bare metal is planned to be removed.
(see http://dpdk.org/ml/archives/dev/2014-June/003868.html)
Objections?
--
Thomas
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h
2014-07-25 10:43 ` Thomas Monjalon
@ 2014-07-25 14:40 ` Antti Kantee
0 siblings, 0 replies; 9+ messages in thread
From: Antti Kantee @ 2014-07-25 14:40 UTC (permalink / raw)
To: Thomas Monjalon, dev
On 25/07/14 10:43, Thomas Monjalon wrote:
>> On 24/07/14 07:59, Matthew Hall wrote:
>>> I ran into some weird symbol conflicts between system netinet/in.h and DPDK
>>> rte_ip.h. They have a lot of duplicated definitions for stuff like IPPROTO_IP
>>> and so on. This breaks when you want to use inet_pton from arpa/inet.h,
>>> because it includes netinet/in.h to define struct in_addr.
> [...]
>> Again, I recommend steering away from any tightrope approaches that
>> "know" which types are non-conflicting, or pick out half-and-half from
>> the host and IP stack. "Do, or do not, there is no half-and-half"
>
> The general problem here is that DPDK is conflicting with libc.
> So the obvious question would be: "why DPDK needs to redefine libc stuff"?
> I don't see any obvious answer since bare metal is planned to be removed.
> (see http://dpdk.org/ml/archives/dev/2014-June/003868.html)
One reason is if you want DPDK to be a portable network programming
environment. Especially in that case you do not want definitions based
on hackish assumptions of some particular version of some particular
host implementation. However, I'm not trying to argue if DPDK should or
shouldn't be that, just that you should either dramatically improve the
current implementation or nuke it.
^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2014-07-25 14:38 UTC | newest]
Thread overview: 9+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-07-24 7:59 [dpdk-dev] symbol conflicts between netinet/in.h, arpa/inet.h, and rte_ip.h Matthew Hall
2014-07-24 15:43 ` Niraj Sharma (nirajsha)
2014-07-24 22:55 ` Antti Kantee
2014-07-24 23:03 ` Matthew Hall
2014-07-25 1:12 ` Wu, Jingjing
2014-07-25 4:56 ` Matthew Hall
2014-07-25 10:33 ` Ananyev, Konstantin
2014-07-25 10:43 ` Thomas Monjalon
2014-07-25 14:40 ` Antti Kantee
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).