?
Solved

netinet/tcp.h -- tcphdr structure compile error

Posted on 2006-06-21
11
Medium Priority
?
2,283 Views
Last Modified: 2008-02-01
Hi experts.

I've written a program to send tcp/ip packets using raw sockets on unix. I've got rid of all the compile errors, except for one remaining problem.

First of all, here are the libraries I've included:

# include <stdio.h>
# include <string.h>
# include <sys/types.h>
# include <sys/socket.h>
# include <netinet/in.h>
# include <netinet/ip.h>
# include <netinet/tcp.h>

My code just basically creates one big buffer and points "ip" and "tcphdr" structures within this buffer. I then fill out all the values and attempt to fire off the packet.

All my remaining compile errors relate to tcphdr... I've looked at /usr/include/tcp.h and cannot make any sense of this at all. The tcphdr structure DOES have the members it is complaining about and they are spelt correctly!

net.c: In function ‘SEND’:
net.c:41: error: ‘struct tcphdr’ has no member named ‘th_sport’
net.c:42: error: ‘struct tcphdr’ has no member named ‘th_dport’
net.c:43: error: ‘struct tcphdr’ has no member named ‘th_seq’
net.c:44: error: ‘struct tcphdr’ has no member named ‘th_ack’
net.c:45: error: ‘struct tcphdr’ has no member named ‘th_x2’
net.c:46: error: ‘struct tcphdr’ has no member named ‘th_off’
net.c:47: error: ‘struct tcphdr’ has no member named ‘th_flags’
net.c:47: error: ‘TH_SYN’ undeclared (first use in this function)
net.c:47: error: (Each undeclared identifier is reported only once
net.c:47: error: for each function it appears in.)
net.c:48: error: ‘struct tcphdr’ has no member named ‘th_win’
net.c:49: error: ‘struct tcphdr’ has no member named ‘th_sum’
net.c:50: error: ‘struct tcphdr’ has no member named ‘th_urp’


I created an instance of the tcphdr structure like this:

struct tcphdr * tcph = ( struct tcphdr * ) datagram + sizeof ( struct ip ) ;



And I was setting the members like follows:

tcph->th_dport = htons ( port ) ;



Suggestions?
0
Comment
Question by:suma_ds
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 6
  • 5
11 Comments
 
LVL 15

Expert Comment

by:bpmurray
ID: 16957825
Sound like you may be including another definition of tcphdr which prevents the one in netinet/tcp.h being seen. Check the -I dirs to make sure you're grabbing the right version.
0
 
LVL 1

Author Comment

by:suma_ds
ID: 16957980
hey thanks for the responce.

i'm new to unix and as such, not quite sure how to do what you're asking. is that a bash command or something to do with gcc?

cheers,
suma
0
 
LVL 15

Expert Comment

by:bpmurray
ID: 16958023
It's to do with gcc. What is your compile command-line?

BTW, what operating system are you doing this on ? Windows? Linux? Some other Unix?
0
Optimize your web performance

What's in the eBook?
- Full list of reasons for poor performance
- Ultimate measures to speed things up
- Primary web monitoring types
- KPIs you should be monitoring in order to increase your ROI

 
LVL 1

Author Comment

by:suma_ds
ID: 16959950
I'm just using  "gcc net.c -o net.exe"  to compile it.

I tried  "gcc -net.c -I dirs -o net.exe"  but that didnt seem to do anything different.

I'm running Linux...
0
 
LVL 1

Author Comment

by:suma_ds
ID: 16962029
I also tried it on a completely different box -- running a different distro of linux. Same problem.
0
 
LVL 15

Expert Comment

by:bpmurray
ID: 16962459
change your compile line to:

    gcc -D__FAVOR_BSD net.c -o net

Just wondering - why call the executable "net.exe" since .exe is Windows only?
0
 
LVL 1

Author Comment

by:suma_ds
ID: 16962595
no joy... i'm still getting the same tcphdr errors.

as for the exe thing, i've just recently migrated from windows.. and although i really do prefer linux,  life without the win32 api is a pretty big change.... so i guess i just call it exe to make it feel more like home :)

btw if it would help at all i could post the complete code of net.c... let me know.

regards,
suma
0
 
LVL 15

Expert Comment

by:bpmurray
ID: 16962704
OK - if you posted the code, it might help. This machine has Windows, but has cygwin, so I should be able to approximate the linux environment.
0
 
LVL 15

Expert Comment

by:bpmurray
ID: 16963155
Just checked ...

If I use gcc 4.0.2 something similar to your code compiles fine, but gcc 3.4.6 fails with the same error you're getting. I looked at the code, and the include files are quite different, although the comments indicate that they're both BSD v8.1. I think it has got to be some -D flag to get it to do the right thing.

I also have another toolchain installed for my GP2X, and that's got the naughty version too, even though this is 4.0.2 too. Hmmmmm! I'll continue to hack ....
0
 
LVL 15

Accepted Solution

by:
bpmurray earned 2000 total points
ID: 16963207
I think I found it. Try this:

      gcc -D_BSD_SOURCE net.c -o net
0
 
LVL 1

Author Comment

by:suma_ds
ID: 16965549
sweet! it works no problem.

many thanks.
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Although it can be difficult to imagine, someday your child will have a career of his or her own. He or she will likely start a family, buy a home and start having their own children. So, while being a kid is still extremely important, it’s also …
Q&A with Course Creator, Mark Lassoff, on the importance of HTML5 in the career of a modern-day developer.
With the power of JIRA, there's an unlimited number of ways you can customize it, use it and benefit from it. With that in mind, there's bound to be things that I wasn't able to cover in this course. With this summary we'll look at some places to go…
In this seventh video of the Xpdf series, we discuss and demonstrate the PDFfonts utility, which lists all the fonts used in a PDF file. It does this via a command line interface, making it suitable for use in programs, scripts, batch files — any pl…

752 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question