summaryrefslogtreecommitdiff
path: root/ghc/lib/misc/cbits/bindSocket.c
blob: b56cb5ec1e126ae91f26659898755e77ce42a73a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#if 0
%
% (c) The GRASP/AQUA Project, Glasgow University, 1995
%
\subsection[bindSocket.lc]{Assign name to unnamed socket}

\begin{code}
#endif

#define NON_POSIX_SOURCE
#include "Rts.h"
#include "ghcSockets.h"
#include "stgio.h"

StgInt
bindSocket(I_ sockfd, A_ myaddr, I_ addrlen, I_ isUnixDomain)
{
    int rc;
    
    while ((rc = bind((int)sockfd, (struct sockaddr *)myaddr, (int)addrlen)) < 0) {
      if (errno != EINTR) {
	  cvtErrno();
	  switch (ghc_errno) {
	  default:
	      stdErrno();
	      break;
	  case GHC_EACCES:
       	      ghc_errtype = ERR_PERMISSIONDENIED;
	      if (isUnixDomain != 0)
	         ghc_errstr = "For a component of path prefix of path name";
	      else
	         ghc_errstr  = "Requested address protected, cannot bind socket";
	      break;
	  case GHC_EISCONN:
	  case GHC_EADDRINUSE:
	      ghc_errtype = ERR_RESOURCEBUSY;
	      ghc_errstr  = "Address already in use";
	      break;
	  case GHC_EADDRNOTAVAIL:
	      ghc_errtype = ERR_PERMISSIONDENIED;
	      ghc_errstr  = "Address not available from local machine";
	      break;
	  case GHC_EBADF:
	      ghc_errtype = ERR_INVALIDARGUMENT;
	      ghc_errstr  = "Not a valid socket file descriptor";
	      break;
	  case GHC_EFAULT:
	      ghc_errtype = ERR_INVALIDARGUMENT;
	      ghc_errstr  = "Address not in valid part of user address space";
	      break;
	  case GHC_EINVAL:
	      ghc_errtype = ERR_SYSTEMERROR;
	      ghc_errstr  = "Specified size of structure not equal valid address for family";
	      break;
	  case GHC_ENOTSOCK:
	      ghc_errtype = ERR_INAPPROPRIATETYPE;
	      ghc_errstr  = "Descriptor for file, not a socket";
	      break;
	  case GHC_EIO:
	      ghc_errtype = ERR_SYSTEMERROR;
	      ghc_errstr  = "Could not make directory entry or alloc inode";
	      break;
	  case GHC_EISDIR:
	      ghc_errtype = ERR_INVALIDARGUMENT;
	      ghc_errstr  = "A null path name was given";
	      break;
	  case GHC_ELOOP:
	      ghc_errtype = ERR_SYSTEMERROR;
	      ghc_errstr  = "Too many symbolic links encountered";
	      break;
	  case GHC_ENAMETOOLONG:
	      ghc_errtype = ERR_INVALIDARGUMENT;
	      ghc_errstr  = "Max length of path name exceeded";
	      break;
	  case GHC_ENOENT:
	      ghc_errtype = ERR_INVALIDARGUMENT;
	      ghc_errstr  = "Component in path prefix does not exist";
	      break;
	  case GHC_ENOTDIR:
	      ghc_errtype = ERR_INVALIDARGUMENT;
	      ghc_errstr  = "Component in path prefix is not a directory";
	      break;
	  case GHC_EROFS:
	      ghc_errtype = ERR_INVALIDARGUMENT;
	      ghc_errstr  = "The inode would reside on read only file system";
	      break;
	  }
	  return -1;
      }
    }
    return 0;
}