OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [newlib-1.17.0/] [newlib/] [libc/] [sys/] [linux/] [net/] [opensock.c] - Blame information for rev 816

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 148 jeremybenn
/* Copyright (C) 1999, 2001, 2002 Free Software Foundation, Inc.
2
   This file is part of the GNU C Library.
3
 
4
   The GNU C Library is free software; you can redistribute it and/or
5
   modify it under the terms of the GNU Lesser General Public
6
   License as published by the Free Software Foundation; either
7
   version 2.1 of the License, or (at your option) any later version.
8
 
9
   The GNU C Library is distributed in the hope that it will be useful,
10
   but WITHOUT ANY WARRANTY; without even the implied warranty of
11
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12
   Lesser General Public License for more details.
13
 
14
   You should have received a copy of the GNU Lesser General Public
15
   License along with the GNU C Library; if not, write to the Free
16
   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
17
   02111-1307 USA.  */
18
 
19
#include <assert.h>
20
#include <errno.h>
21
#include <stdio.h>
22
#include <string.h>
23
#include <unistd.h>
24
#include <sys/socket.h>
25
#include "libc-symbols.h"
26
 
27
/* Return a socket of any type.  The socket can be used in subsequent
28
   ioctl calls to talk to the kernel.  */
29
int internal_function
30
__opensock (void)
31
{
32
  static int last_family;       /* Available socket family we will use.  */
33
  static int last_type;
34
  static const struct
35
  {
36
    int family;
37
    const char procname[15];
38
  } afs[] =
39
    {
40
      /* The 2.2 kernels cannot handle ioctl(SIOCGIFCONF) on AF_UNIX sockets.
41
         Give the kernel a chance to user inet sockets on old kernels.  */
42
#if __LINUX_KERNEL_VERSION < 132096
43
      { AF_INET, "" },
44
      { AF_UNIX, "net/unix" },
45
#else
46
      { AF_UNIX, "net/unix" },
47
      { AF_INET, "" },
48
#endif
49
      { AF_INET6, "net/if_inet6" },
50
      { AF_AX25, "net/ax25" },
51
      { AF_NETROM, "net/nr" },
52
      { AF_ROSE, "net/rose" },
53
      { AF_IPX, "net/ipx" },
54
      { AF_APPLETALK, "net/appletalk" },
55
      { AF_ECONET, "sys/net/econet" },
56
      { AF_ASH, "sys/net/ash" },
57
      { AF_X25, "net/x25" }
58
    };
59
#define nafs (sizeof (afs) / sizeof (afs[0]))
60
  char fname[sizeof "/proc/" + 14];
61
  int result;
62
  int has_proc;
63
  size_t cnt;
64
 
65
  /* We already know which family to use from the last call.  Use it
66
     again.  */
67
  if (last_family != 0)
68
    {
69
      assert (last_type != 0);
70
 
71
      result = socket (last_family, last_type, 0);
72
      if (result != -1 || errno != EAFNOSUPPORT)
73
        /* Maybe the socket type isn't supported anymore (module is
74
           unloaded).  In this case again try to find the type.  */
75
        return result;
76
 
77
      /* Reset the values.  They seem not valid anymore.  */
78
      last_family = 0;
79
      last_type = 0;
80
    }
81
 
82
  /* Check whether the /proc filesystem is available.  */
83
  has_proc = access ("/proc/net", R_OK) != -1;
84
  strcpy (fname, "/proc/");
85
 
86
  /* Iterate over the interface families and find one which is
87
     available.  */
88
  for (cnt = 0; cnt < nafs; ++cnt)
89
    {
90
      int type = SOCK_DGRAM;
91
 
92
      if (has_proc && afs[cnt].procname[0] != '\0')
93
        {
94
          strcpy (fname + 6, afs[cnt].procname);
95
          if (access (fname, R_OK) == -1)
96
            /* The /proc entry is not available.  I.e., we cannot
97
               create a socket of this type (without loading the
98
               module).  Don't look for it since this might trigger
99
               loading the module.  */
100
            continue;
101
        }
102
 
103
      if (afs[cnt].family == AF_NETROM || afs[cnt].family == AF_X25)
104
        type = SOCK_SEQPACKET;
105
 
106
      result = socket (afs[cnt].family, type, 0);
107
      if (result != -1)
108
        {
109
          /* Found an available family.  */
110
          last_type = type;
111
          last_family = afs[cnt].family;
112
          return result;
113
        }
114
    }
115
 
116
  /* None of the protocol families is available.  It is unclear what kind
117
     of error is returned.  ENOENT seems like a reasonable choice.  */
118
  __set_errno (ENOENT);
119
  return -1;
120
}

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.