Solved

error calling socket()

Posted on 2004-09-06
4
1,763 Views
Last Modified: 2008-02-26
My code is as follows:

      /* Create the socket */
      s = socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
      if(s == INVALID_SOCKET)
      {
            FILE *f = fopen("c:\\temp\\lsp.txt","a");
            fprintf(f,"socket() error: %d\n",WSAGetLastError());
            fclose(f);
            return 0;
      }

The error number returned by WSAGetLastError() is 183.  I looked in the winsock2.h header file, and I cant find any sort of reference to 183.  I'm hoping someone here can help me figure out this error.
0
Comment
Question by:lwinkenb
4 Comments
 
LVL 15

Expert Comment

by:efn
Comment Utility
First, you should capture the value from WSAGetLastError before calling fopen, because fopen can change the value.  Just save the value in a variable and use the variable after fopen to put out the value.

Second, do you have a call to WSAStartup before the code you showed?  It's necessary to initialize the library before you try to create a socket.

--efn
0
 
LVL 86

Expert Comment

by:jkr
Comment Utility
Do you call 'WSAStartup()' before calling 'socket()'?

WORD wVersionRequested;
WSADATA wsaData;
int err;
 
wVersionRequested = MAKEWORD( 2, 2 );
 
err = WSAStartup( wVersionRequested, &wsaData );
if ( err != 0 ) {
    /* Tell the user that we could not find a usable */
    /* WinSock DLL.                                  */
    return;
}


Apart from that, try

     /* Create the socket */
    s = socket(AF_INET,SOCK_STREAM,0);
0
 
LVL 5

Author Comment

by:lwinkenb
Comment Utility
I was already calling WSAStartup(), so that isnt the problem.  I moved the WSAGetLastError() to a new line before the called to fopen(), and now it is giving me a legitamate error.  The error is WSAEPROVIDERFAILEDINIT.

I'm not sure exactly why I'm getting this error, but I think it's due to the fact that Im making the socket() call in DllMain() of a Layered Service Provider DLL.  
0
 
LVL 1

Accepted Solution

by:
jonathan6587 earned 500 total points
Comment Utility
lwinkenb

Error 183 is:

"Cannot create a file when that file already exists."

Probably something to do with your "lsp.txt"

I suspect it is your use of fopen, specifically "a"

"a" opens the file for appending, but does not remove the end of file marker before writing new data -- thus if this is any type of loop or you've appended the file previously without closing the fclosing the file -- you would probably get an error like this.  I suggest you use "a+" -- it removes the end of file marker before new data is written and restores the marker after your done writing.


You can use the FormatMessage function to convert error number to the error message.

I'm not sure you care about this now, but it's good to know.

Also, you can type "net helpmsg 183" on the command line and it will convert the error number to a meaningful message.

Cheers,

Jonathan

0

Featured Post

Why You Should Analyze Threat Actor TTPs

After years of analyzing threat actor behavior, it’s become clear that at any given time there are specific tactics, techniques, and procedures (TTPs) that are particularly prevalent. By analyzing and understanding these TTPs, you can dramatically enhance your security program.

Join & Write a Comment

Preface I don't like visual development tools that are supposed to write a program for me. Even if it is Xcode and I can use Interface Builder. Yes, it is a perfect tool and has helped me a lot, mainly, in the beginning, when my programs were small…
This tutorial is posted by Aaron Wojnowski, administrator at SDKExpert.net.  To view more iPhone tutorials, visit www.sdkexpert.net. This is a very simple tutorial on finding the user's current location easily. In this tutorial, you will learn ho…
The goal of this video is to provide viewers with basic examples to understand how to use strings and some functions related to them in the C programming language.
Video by: Grant
The goal of this video is to provide viewers with basic examples to understand and use while-loops in the C programming language.

728 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

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now