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

Subversion Repositories or1k_old

[/] [or1k_old/] [trunk/] [rc203soc/] [sw/] [uClinux/] [include/] [net/] [sock.h] - Diff between revs 1765 and 1782

Only display areas with differences | Details | Blame | View Log

Rev 1765 Rev 1782
/*
/*
 * INET         An implementation of the TCP/IP protocol suite for the LINUX
 * INET         An implementation of the TCP/IP protocol suite for the LINUX
 *              operating system.  INET is implemented using the  BSD Socket
 *              operating system.  INET is implemented using the  BSD Socket
 *              interface as the means of communication with the user level.
 *              interface as the means of communication with the user level.
 *
 *
 *              Definitions for the AF_INET socket handler.
 *              Definitions for the AF_INET socket handler.
 *
 *
 * Version:     @(#)sock.h      1.0.4   05/13/93
 * Version:     @(#)sock.h      1.0.4   05/13/93
 *
 *
 * Authors:     Ross Biro, <bir7@leland.Stanford.Edu>
 * Authors:     Ross Biro, <bir7@leland.Stanford.Edu>
 *              Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
 *              Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
 *              Corey Minyard <wf-rch!minyard@relay.EU.net>
 *              Corey Minyard <wf-rch!minyard@relay.EU.net>
 *              Florian La Roche <flla@stud.uni-sb.de>
 *              Florian La Roche <flla@stud.uni-sb.de>
 *
 *
 * Fixes:
 * Fixes:
 *              Alan Cox        :       Volatiles in skbuff pointers. See
 *              Alan Cox        :       Volatiles in skbuff pointers. See
 *                                      skbuff comments. May be overdone,
 *                                      skbuff comments. May be overdone,
 *                                      better to prove they can be removed
 *                                      better to prove they can be removed
 *                                      than the reverse.
 *                                      than the reverse.
 *              Alan Cox        :       Added a zapped field for tcp to note
 *              Alan Cox        :       Added a zapped field for tcp to note
 *                                      a socket is reset and must stay shut up
 *                                      a socket is reset and must stay shut up
 *              Alan Cox        :       New fields for options
 *              Alan Cox        :       New fields for options
 *      Pauline Middelink       :       identd support
 *      Pauline Middelink       :       identd support
 *              Alan Cox        :       Eliminate low level recv/recvfrom
 *              Alan Cox        :       Eliminate low level recv/recvfrom
 *              David S. Miller :       New socket lookup architecture for ISS.
 *              David S. Miller :       New socket lookup architecture for ISS.
 *              Elliot Poger    :       New field for SO_BINDTODEVICE option.
 *              Elliot Poger    :       New field for SO_BINDTODEVICE option.
 *
 *
 *              This program is free software; you can redistribute it and/or
 *              This program is free software; you can redistribute it and/or
 *              modify it under the terms of the GNU General Public License
 *              modify it under the terms of the GNU General Public License
 *              as published by the Free Software Foundation; either version
 *              as published by the Free Software Foundation; either version
 *              2 of the License, or (at your option) any later version.
 *              2 of the License, or (at your option) any later version.
 */
 */
#ifndef _SOCK_H
#ifndef _SOCK_H
#define _SOCK_H
#define _SOCK_H
 
 
#include <linux/timer.h>
#include <linux/timer.h>
#include <linux/ip.h>           /* struct options */
#include <linux/ip.h>           /* struct options */
#include <linux/in.h>           /* struct sockaddr_in */
#include <linux/in.h>           /* struct sockaddr_in */
#include <linux/tcp.h>          /* struct tcphdr */
#include <linux/tcp.h>          /* struct tcphdr */
#include <linux/config.h>
#include <linux/config.h>
 
 
#include <linux/netdevice.h>
#include <linux/netdevice.h>
#include <linux/skbuff.h>       /* struct sk_buff */
#include <linux/skbuff.h>       /* struct sk_buff */
#include <net/protocol.h>               /* struct inet_protocol */
#include <net/protocol.h>               /* struct inet_protocol */
#if defined(CONFIG_AX25) || defined(CONFIG_AX25_MODULE)
#if defined(CONFIG_AX25) || defined(CONFIG_AX25_MODULE)
#include <net/ax25.h>
#include <net/ax25.h>
#if defined(CONFIG_NETROM) || defined(CONFIG_NETROM_MODULE)
#if defined(CONFIG_NETROM) || defined(CONFIG_NETROM_MODULE)
#include <net/netrom.h>
#include <net/netrom.h>
#endif
#endif
#if defined(CONFIG_ROSE) || defined(CONFIG_ROSE_MODULE)
#if defined(CONFIG_ROSE) || defined(CONFIG_ROSE_MODULE)
#include <net/rose.h>
#include <net/rose.h>
#endif
#endif
#endif
#endif
 
 
#if defined(CONFIG_IPX) || defined(CONFIG_IPX_MODULE)
#if defined(CONFIG_IPX) || defined(CONFIG_IPX_MODULE)
#include <net/ipx.h>
#include <net/ipx.h>
#endif
#endif
 
 
#if defined(CONFIG_ATALK) || defined(CONFIG_ATALK_MODULE)
#if defined(CONFIG_ATALK) || defined(CONFIG_ATALK_MODULE)
#include <linux/atalk.h>
#include <linux/atalk.h>
#endif
#endif
 
 
#include <linux/igmp.h>
#include <linux/igmp.h>
 
 
#include <asm/atomic.h>
#include <asm/atomic.h>
 
 
/*
/*
 *      The AF_UNIX specific socket options
 *      The AF_UNIX specific socket options
 */
 */
 
 
struct unix_opt
struct unix_opt
{
{
        int                     family;
        int                     family;
        char *                  name;
        char *                  name;
        int                     locks;
        int                     locks;
        struct inode *          inode;
        struct inode *          inode;
        struct semaphore        readsem;
        struct semaphore        readsem;
        struct sock *           other;
        struct sock *           other;
        int                     marksweep;
        int                     marksweep;
#define MARKED                  1
#define MARKED                  1
        int                     inflight;
        int                     inflight;
};
};
 
 
/*
/*
 *      IP packet socket options
 *      IP packet socket options
 */
 */
 
 
struct inet_packet_opt
struct inet_packet_opt
{
{
        struct notifier_block   notifier;               /* Used when bound */
        struct notifier_block   notifier;               /* Used when bound */
        struct device           *bound_dev;
        struct device           *bound_dev;
        unsigned long           dev_stamp;
        unsigned long           dev_stamp;
        struct packet_type      *prot_hook;
        struct packet_type      *prot_hook;
        char                    device_name[15];
        char                    device_name[15];
};
};
 
 
/*
/*
 *      Once the IPX ncpd patches are in these are going into protinfo
 *      Once the IPX ncpd patches are in these are going into protinfo
 */
 */
 
 
#if defined(CONFIG_IPX) || defined(CONFIG_IPX_MODULE)
#if defined(CONFIG_IPX) || defined(CONFIG_IPX_MODULE)
struct ipx_opt
struct ipx_opt
{
{
        ipx_address             dest_addr;
        ipx_address             dest_addr;
        ipx_interface           *intrfc;
        ipx_interface           *intrfc;
        unsigned short          port;
        unsigned short          port;
#ifdef CONFIG_IPX_INTERN
#ifdef CONFIG_IPX_INTERN
        unsigned char           node[IPX_NODE_LEN];
        unsigned char           node[IPX_NODE_LEN];
#endif
#endif
        unsigned short          type;
        unsigned short          type;
/*
/*
 * To handle asynchronous messages from the NetWare server, we have to
 * To handle asynchronous messages from the NetWare server, we have to
 * know the connection this socket belongs to.
 * know the connection this socket belongs to.
 */
 */
        struct ncp_server       *ncp_server;
        struct ncp_server       *ncp_server;
/*
/*
 * To handle special ncp connection-handling sockets for mars_nwe,
 * To handle special ncp connection-handling sockets for mars_nwe,
 * the connection number must be stored in the socket.
 * the connection number must be stored in the socket.
 */
 */
        unsigned short          ipx_ncp_conn;
        unsigned short          ipx_ncp_conn;
};
};
#endif
#endif
 
 
#ifdef CONFIG_NUTCP
#ifdef CONFIG_NUTCP
struct tcp_opt
struct tcp_opt
{
{
/*
/*
 *      RFC793 variables by their proper names. This means you can
 *      RFC793 variables by their proper names. This means you can
 *      read the code and the spec side by side (and laugh ...)
 *      read the code and the spec side by side (and laugh ...)
 *      See RFC793 and RFC1122. The RFC writes these in capitals.
 *      See RFC793 and RFC1122. The RFC writes these in capitals.
 */
 */
        __u32   rcv_nxt;        /* What we want to receive next         */
        __u32   rcv_nxt;        /* What we want to receive next         */
        __u32   rcv_up;         /* The urgent point (may not be valid)  */
        __u32   rcv_up;         /* The urgent point (may not be valid)  */
        __u32   rcv_wnd;        /* Current receiver window              */
        __u32   rcv_wnd;        /* Current receiver window              */
        __u32   snd_nxt;        /* Next sequence we send                */
        __u32   snd_nxt;        /* Next sequence we send                */
        __u32   snd_una;        /* First byte we want an ack for        */
        __u32   snd_una;        /* First byte we want an ack for        */
        __u32   snd_up;         /* Outgoing urgent pointer              */
        __u32   snd_up;         /* Outgoing urgent pointer              */
        __u32   snd_wl1;        /* Sequence for window update           */
        __u32   snd_wl1;        /* Sequence for window update           */
        __u32   snd_wl2;        /* Ack sequence for update              */
        __u32   snd_wl2;        /* Ack sequence for update              */
/*
/*
 *      Slow start and congestion control (see also Nagle, and Karn & Partridge)
 *      Slow start and congestion control (see also Nagle, and Karn & Partridge)
 */
 */
        __u32   snd_cwnd;       /* Sending congestion window            */
        __u32   snd_cwnd;       /* Sending congestion window            */
        __u32   snd_ssthresh;   /* Slow start size threshold            */
        __u32   snd_ssthresh;   /* Slow start size threshold            */
/*
/*
 *      Timers used by the TCP protocol layer
 *      Timers used by the TCP protocol layer
 */
 */
        struct timer_list       delack_timer;           /* Ack delay    */
        struct timer_list       delack_timer;           /* Ack delay    */
        struct timer_list       idle_timer;             /* Idle watch   */
        struct timer_list       idle_timer;             /* Idle watch   */
        struct timer_list       completion_timer;       /* Up/Down timer */
        struct timer_list       completion_timer;       /* Up/Down timer */
        struct timer_list       probe_timer;            /* Probes       */
        struct timer_list       probe_timer;            /* Probes       */
        struct timer_list       retransmit_timer;       /* Resend (no ack) */
        struct timer_list       retransmit_timer;       /* Resend (no ack) */
};
};
#endif
#endif
 
 
/*
/*
 * This structure really needs to be cleaned up.
 * This structure really needs to be cleaned up.
 * Most of it is for TCP, and not used by any of
 * Most of it is for TCP, and not used by any of
 * the other protocols.
 * the other protocols.
 */
 */
struct sock
struct sock
{
{
        /* This must be first. */
        /* This must be first. */
        struct sock             *sklist_next;
        struct sock             *sklist_next;
        struct sock             *sklist_prev;
        struct sock             *sklist_prev;
 
 
        struct options          *opt;
        struct options          *opt;
        atomic_t                wmem_alloc;
        atomic_t                wmem_alloc;
        atomic_t                rmem_alloc;
        atomic_t                rmem_alloc;
        unsigned long           allocation;             /* Allocation mode */
        unsigned long           allocation;             /* Allocation mode */
        __u32                   write_seq;
        __u32                   write_seq;
        __u32                   sent_seq;
        __u32                   sent_seq;
        __u32                   acked_seq;
        __u32                   acked_seq;
        __u32                   copied_seq;
        __u32                   copied_seq;
        __u32                   rcv_ack_seq;
        __u32                   rcv_ack_seq;
        unsigned short          rcv_ack_cnt;            /* count of same ack */
        unsigned short          rcv_ack_cnt;            /* count of same ack */
        __u32                   window_seq;
        __u32                   window_seq;
        __u32                   fin_seq;
        __u32                   fin_seq;
        __u32                   urg_seq;
        __u32                   urg_seq;
        __u32                   urg_data;
        __u32                   urg_data;
        __u32                   syn_seq;
        __u32                   syn_seq;
        int                     users;                  /* user count */
        int                     users;                  /* user count */
  /*
  /*
   *    Not all are volatile, but some are, so we
   *    Not all are volatile, but some are, so we
   *    might as well say they all are.
   *    might as well say they all are.
   */
   */
        volatile char           dead,
        volatile char           dead,
                                urginline,
                                urginline,
                                intr,
                                intr,
                                blog,
                                blog,
                                done,
                                done,
                                reuse,
                                reuse,
                                keepopen,
                                keepopen,
                                linger,
                                linger,
                                delay_acks,
                                delay_acks,
                                destroy,
                                destroy,
                                ack_timed,
                                ack_timed,
                                no_check,
                                no_check,
                                zapped, /* In ax25 & ipx means not linked */
                                zapped, /* In ax25 & ipx means not linked */
                                broadcast,
                                broadcast,
                                nonagle,
                                nonagle,
                                bsdism;
                                bsdism;
        struct device           * bound_device;
        struct device           * bound_device;
        unsigned long           lingertime;
        unsigned long           lingertime;
        int                     proc;
        int                     proc;
 
 
        struct sock             *next;
        struct sock             *next;
        struct sock             **pprev;
        struct sock             **pprev;
        struct sock             *bind_next;
        struct sock             *bind_next;
        struct sock             **bind_pprev;
        struct sock             **bind_pprev;
        struct sock             *pair;
        struct sock             *pair;
        int                     hashent;
        int                     hashent;
        struct sock             *prev;
        struct sock             *prev;
        struct sk_buff          * volatile send_head;
        struct sk_buff          * volatile send_head;
        struct sk_buff          * volatile send_next;
        struct sk_buff          * volatile send_next;
        struct sk_buff          * volatile send_tail;
        struct sk_buff          * volatile send_tail;
        struct sk_buff_head     back_log;
        struct sk_buff_head     back_log;
        struct sk_buff          *partial;
        struct sk_buff          *partial;
        struct timer_list       partial_timer;
        struct timer_list       partial_timer;
        long                    retransmits;
        long                    retransmits;
        struct sk_buff_head     write_queue,
        struct sk_buff_head     write_queue,
                                receive_queue;
                                receive_queue;
        struct proto            *prot;
        struct proto            *prot;
        struct wait_queue       **sleep;
        struct wait_queue       **sleep;
        __u32                   daddr;
        __u32                   daddr;
        __u32                   saddr;          /* Sending source */
        __u32                   saddr;          /* Sending source */
        __u32                   rcv_saddr;      /* Bound address */
        __u32                   rcv_saddr;      /* Bound address */
        unsigned short          max_unacked;
        unsigned short          max_unacked;
        unsigned short          window;
        unsigned short          window;
        __u32                   lastwin_seq;    /* sequence number when we last updated the window we offer */
        __u32                   lastwin_seq;    /* sequence number when we last updated the window we offer */
        __u32                   high_seq;       /* sequence number when we did current fast retransmit */
        __u32                   high_seq;       /* sequence number when we did current fast retransmit */
        volatile unsigned long  ato;            /* ack timeout */
        volatile unsigned long  ato;            /* ack timeout */
        volatile unsigned long  lrcvtime;       /* jiffies at last data rcv */
        volatile unsigned long  lrcvtime;       /* jiffies at last data rcv */
        volatile unsigned long  idletime;       /* jiffies at last rcv */
        volatile unsigned long  idletime;       /* jiffies at last rcv */
        unsigned int            bytes_rcv;
        unsigned int            bytes_rcv;
/*
/*
 *      mss is min(mtu, max_window)
 *      mss is min(mtu, max_window)
 */
 */
        unsigned short          mtu;       /* mss negotiated in the syn's */
        unsigned short          mtu;       /* mss negotiated in the syn's */
        volatile unsigned short mss;       /* current eff. mss - can change */
        volatile unsigned short mss;       /* current eff. mss - can change */
        volatile unsigned short user_mss;  /* mss requested by user in ioctl */
        volatile unsigned short user_mss;  /* mss requested by user in ioctl */
        volatile unsigned short max_window;
        volatile unsigned short max_window;
        unsigned long           window_clamp;
        unsigned long           window_clamp;
        unsigned int            ssthresh;
        unsigned int            ssthresh;
        unsigned short          num;
        unsigned short          num;
        volatile unsigned short cong_window;
        volatile unsigned short cong_window;
        volatile unsigned short cong_count;
        volatile unsigned short cong_count;
        volatile unsigned short packets_out;
        volatile unsigned short packets_out;
        volatile unsigned short shutdown;
        volatile unsigned short shutdown;
        volatile unsigned long  rtt;
        volatile unsigned long  rtt;
        volatile unsigned long  mdev;
        volatile unsigned long  mdev;
        volatile unsigned long  rto;
        volatile unsigned long  rto;
 
 
/*
/*
 *      currently backoff isn't used, but I'm maintaining it in case
 *      currently backoff isn't used, but I'm maintaining it in case
 *      we want to go back to a backoff formula that needs it
 *      we want to go back to a backoff formula that needs it
 */
 */
 
 
        volatile unsigned short backoff;
        volatile unsigned short backoff;
        int                     err, err_soft;  /* Soft holds errors that don't
        int                     err, err_soft;  /* Soft holds errors that don't
                                                   cause failure but are the cause
                                                   cause failure but are the cause
                                                   of a persistent failure not just
                                                   of a persistent failure not just
                                                   'timed out' */
                                                   'timed out' */
        unsigned char           protocol;
        unsigned char           protocol;
        volatile unsigned char  state;
        volatile unsigned char  state;
        unsigned short          ack_backlog;
        unsigned short          ack_backlog;
        unsigned char           priority;
        unsigned char           priority;
        unsigned char           debug;
        unsigned char           debug;
        int                     rcvbuf;
        int                     rcvbuf;
        int                     sndbuf;
        int                     sndbuf;
        unsigned short          type;
        unsigned short          type;
        unsigned char           localroute;     /* Route locally only */
        unsigned char           localroute;     /* Route locally only */
 
 
/*
/*
 *      This is where all the private (optional) areas that don't
 *      This is where all the private (optional) areas that don't
 *      overlap will eventually live.
 *      overlap will eventually live.
 */
 */
 
 
        union
        union
        {
        {
                struct unix_opt af_unix;
                struct unix_opt af_unix;
#if defined(CONFIG_AX25) || defined(CONFIG_AX25_MODULE)
#if defined(CONFIG_AX25) || defined(CONFIG_AX25_MODULE)
                ax25_cb                 *ax25;
                ax25_cb                 *ax25;
#if defined(CONFIG_NETROM) || defined(CONFIG_NETROM_MODULE)
#if defined(CONFIG_NETROM) || defined(CONFIG_NETROM_MODULE)
                nr_cb                   *nr;
                nr_cb                   *nr;
#endif
#endif
#if defined(CONFIG_ROSE) || defined(CONFIG_ROSE_MODULE)
#if defined(CONFIG_ROSE) || defined(CONFIG_ROSE_MODULE)
                rose_cb                 *rose;
                rose_cb                 *rose;
#endif
#endif
#endif
#endif
#if defined(CONFIG_ATALK) || defined(CONFIG_ATALK_MODULE)
#if defined(CONFIG_ATALK) || defined(CONFIG_ATALK_MODULE)
                struct atalk_sock       af_at;
                struct atalk_sock       af_at;
#endif
#endif
#if defined(CONFIG_IPX) || defined(CONFIG_IPX_MODULE)
#if defined(CONFIG_IPX) || defined(CONFIG_IPX_MODULE)
                struct ipx_opt          af_ipx;
                struct ipx_opt          af_ipx;
#endif
#endif
#ifdef CONFIG_INET
#ifdef CONFIG_INET
                struct inet_packet_opt  af_packet;
                struct inet_packet_opt  af_packet;
#ifdef CONFIG_NUTCP             
#ifdef CONFIG_NUTCP             
                struct tcp_opt          af_tcp;
                struct tcp_opt          af_tcp;
#endif          
#endif          
#endif
#endif
        } protinfo;
        } protinfo;
 
 
/*
/*
 *      IP 'private area' or will be eventually
 *      IP 'private area' or will be eventually
 */
 */
        int                     ip_ttl;                 /* TTL setting */
        int                     ip_ttl;                 /* TTL setting */
        int                     ip_tos;                 /* TOS */
        int                     ip_tos;                 /* TOS */
        struct tcphdr           dummy_th;
        struct tcphdr           dummy_th;
        struct timer_list       keepalive_timer;        /* TCP keepalive hack */
        struct timer_list       keepalive_timer;        /* TCP keepalive hack */
        struct timer_list       retransmit_timer;       /* TCP retransmit timer */
        struct timer_list       retransmit_timer;       /* TCP retransmit timer */
        struct timer_list       delack_timer;           /* TCP delayed ack timer */
        struct timer_list       delack_timer;           /* TCP delayed ack timer */
        int                     ip_xmit_timeout;        /* Why the timeout is running */
        int                     ip_xmit_timeout;        /* Why the timeout is running */
        struct rtable           *ip_route_cache;        /* Cached output route */
        struct rtable           *ip_route_cache;        /* Cached output route */
        unsigned char           ip_hdrincl;             /* Include headers ? */
        unsigned char           ip_hdrincl;             /* Include headers ? */
#ifdef CONFIG_IP_MULTICAST  
#ifdef CONFIG_IP_MULTICAST  
        int                     ip_mc_ttl;              /* Multicasting TTL */
        int                     ip_mc_ttl;              /* Multicasting TTL */
        int                     ip_mc_loop;             /* Loopback */
        int                     ip_mc_loop;             /* Loopback */
        char                    ip_mc_name[MAX_ADDR_LEN];/* Multicast device name */
        char                    ip_mc_name[MAX_ADDR_LEN];/* Multicast device name */
        struct ip_mc_socklist   *ip_mc_list;            /* Group array */
        struct ip_mc_socklist   *ip_mc_list;            /* Group array */
#endif  
#endif  
 
 
/*
/*
 *      This part is used for the timeout functions (timer.c).
 *      This part is used for the timeout functions (timer.c).
 */
 */
 
 
        int                     timeout;        /* What are we waiting for? */
        int                     timeout;        /* What are we waiting for? */
        struct timer_list       timer;          /* This is the TIME_WAIT/receive timer
        struct timer_list       timer;          /* This is the TIME_WAIT/receive timer
                                         * when we are doing IP
                                         * when we are doing IP
                                         */
                                         */
        struct timeval          stamp;
        struct timeval          stamp;
 
 
 /*
 /*
  *     Identd
  *     Identd
  */
  */
 
 
        struct socket           *socket;
        struct socket           *socket;
 
 
  /*
  /*
   *    Callbacks
   *    Callbacks
   */
   */
 
 
        void                    (*state_change)(struct sock *sk);
        void                    (*state_change)(struct sock *sk);
        void                    (*data_ready)(struct sock *sk,int bytes);
        void                    (*data_ready)(struct sock *sk,int bytes);
        void                    (*write_space)(struct sock *sk);
        void                    (*write_space)(struct sock *sk);
        void                    (*error_report)(struct sock *sk);
        void                    (*error_report)(struct sock *sk);
 
 
  /*
  /*
   *    Moved solely for 2.0 to keep binary module compatibility stuff straight.
   *    Moved solely for 2.0 to keep binary module compatibility stuff straight.
   */
   */
 
 
        unsigned short          max_ack_backlog;
        unsigned short          max_ack_backlog;
        struct sock             *listening;
        struct sock             *listening;
};
};
 
 
/*
/*
 *      IP protocol blocks we attach to sockets.
 *      IP protocol blocks we attach to sockets.
 */
 */
 
 
struct proto
struct proto
{
{
        /* These must be first. */
        /* These must be first. */
        struct sock             *sklist_next;
        struct sock             *sklist_next;
        struct sock             *sklist_prev;
        struct sock             *sklist_prev;
 
 
        void                    (*close)(struct sock *sk, unsigned long timeout);
        void                    (*close)(struct sock *sk, unsigned long timeout);
        int                     (*build_header)(struct sk_buff *skb,
        int                     (*build_header)(struct sk_buff *skb,
                                        __u32 saddr,
                                        __u32 saddr,
                                        __u32 daddr,
                                        __u32 daddr,
                                        struct device **dev, int type,
                                        struct device **dev, int type,
                                        struct options *opt, int len,
                                        struct options *opt, int len,
                                        int tos, int ttl, struct rtable ** rp);
                                        int tos, int ttl, struct rtable ** rp);
        int                     (*connect)(struct sock *sk,
        int                     (*connect)(struct sock *sk,
                                        struct sockaddr_in *usin, int addr_len);
                                        struct sockaddr_in *usin, int addr_len);
        struct sock *           (*accept) (struct sock *sk, int flags);
        struct sock *           (*accept) (struct sock *sk, int flags);
        void                    (*queue_xmit)(struct sock *sk,
        void                    (*queue_xmit)(struct sock *sk,
                                        struct device *dev, struct sk_buff *skb,
                                        struct device *dev, struct sk_buff *skb,
                                        int free);
                                        int free);
        void                    (*retransmit)(struct sock *sk, int all);
        void                    (*retransmit)(struct sock *sk, int all);
        void                    (*write_wakeup)(struct sock *sk);
        void                    (*write_wakeup)(struct sock *sk);
        void                    (*read_wakeup)(struct sock *sk);
        void                    (*read_wakeup)(struct sock *sk);
        int                     (*rcv)(struct sk_buff *buff, struct device *dev,
        int                     (*rcv)(struct sk_buff *buff, struct device *dev,
                                        struct options *opt, __u32 daddr,
                                        struct options *opt, __u32 daddr,
                                        unsigned short len, __u32 saddr,
                                        unsigned short len, __u32 saddr,
                                        int redo, struct inet_protocol *protocol);
                                        int redo, struct inet_protocol *protocol);
        int                     (*select)(struct sock *sk, int which,
        int                     (*select)(struct sock *sk, int which,
                                        select_table *wait);
                                        select_table *wait);
        int                     (*ioctl)(struct sock *sk, int cmd,
        int                     (*ioctl)(struct sock *sk, int cmd,
                                        unsigned long arg);
                                        unsigned long arg);
        int                     (*init)(struct sock *sk);
        int                     (*init)(struct sock *sk);
        void                    (*shutdown)(struct sock *sk, int how);
        void                    (*shutdown)(struct sock *sk, int how);
        int                     (*setsockopt)(struct sock *sk, int level, int optname,
        int                     (*setsockopt)(struct sock *sk, int level, int optname,
                                        char *optval, int optlen);
                                        char *optval, int optlen);
        int                     (*getsockopt)(struct sock *sk, int level, int optname,
        int                     (*getsockopt)(struct sock *sk, int level, int optname,
                                        char *optval, int *option);
                                        char *optval, int *option);
        int                     (*sendmsg)(struct sock *sk, struct msghdr *msg, int len,
        int                     (*sendmsg)(struct sock *sk, struct msghdr *msg, int len,
                                        int noblock, int flags);
                                        int noblock, int flags);
        int                     (*recvmsg)(struct sock *sk, struct msghdr *msg, int len,
        int                     (*recvmsg)(struct sock *sk, struct msghdr *msg, int len,
                                        int noblock, int flags, int *addr_len);
                                        int noblock, int flags, int *addr_len);
        int                     (*bind)(struct sock *sk, struct sockaddr *uaddr, int addr_len);
        int                     (*bind)(struct sock *sk, struct sockaddr *uaddr, int addr_len);
 
 
        /* Keeping track of sk's, looking them up, and port selection methods. */
        /* Keeping track of sk's, looking them up, and port selection methods. */
        void                    (*hash)(struct sock *sk);
        void                    (*hash)(struct sock *sk);
        void                    (*unhash)(struct sock *sk);
        void                    (*unhash)(struct sock *sk);
        void                    (*rehash)(struct sock *sk);
        void                    (*rehash)(struct sock *sk);
        unsigned short          (*good_socknum)(void);
        unsigned short          (*good_socknum)(void);
        int                     (*verify_bind)(struct sock *sk, unsigned short snum);
        int                     (*verify_bind)(struct sock *sk, unsigned short snum);
 
 
        unsigned short          max_header;
        unsigned short          max_header;
        unsigned long           retransmits;
        unsigned long           retransmits;
        char                    name[32];
        char                    name[32];
        int                     inuse, highestinuse;
        int                     inuse, highestinuse;
};
};
 
 
#define TIME_WRITE      1
#define TIME_WRITE      1
#define TIME_CLOSE      2
#define TIME_CLOSE      2
#define TIME_KEEPOPEN   3
#define TIME_KEEPOPEN   3
#define TIME_DESTROY    4
#define TIME_DESTROY    4
#define TIME_DONE       5       /* Used to absorb those last few packets */
#define TIME_DONE       5       /* Used to absorb those last few packets */
#define TIME_PROBE0     6
#define TIME_PROBE0     6
 
 
/*
/*
 *      About 10 seconds
 *      About 10 seconds
 */
 */
 
 
#define SOCK_DESTROY_TIME (10*HZ)
#define SOCK_DESTROY_TIME (10*HZ)
 
 
/*
/*
 *      Sockets 0-1023 can't be bound to unless you are superuser
 *      Sockets 0-1023 can't be bound to unless you are superuser
 */
 */
 
 
#define PROT_SOCK       1024
#define PROT_SOCK       1024
 
 
#define SHUTDOWN_MASK   3
#define SHUTDOWN_MASK   3
#define RCV_SHUTDOWN    1
#define RCV_SHUTDOWN    1
#define SEND_SHUTDOWN   2
#define SEND_SHUTDOWN   2
 
 
/* Per-protocol hash table implementations use this to make sure
/* Per-protocol hash table implementations use this to make sure
 * nothing changes.
 * nothing changes.
 */
 */
#define SOCKHASH_LOCK()         start_bh_atomic()
#define SOCKHASH_LOCK()         start_bh_atomic()
#define SOCKHASH_UNLOCK()       end_bh_atomic()
#define SOCKHASH_UNLOCK()       end_bh_atomic()
 
 
/* Some things in the kernel just want to get at a protocols
/* Some things in the kernel just want to get at a protocols
 * entire socket list commensurate, thus...
 * entire socket list commensurate, thus...
 */
 */
static __inline__ void add_to_prot_sklist(struct sock *sk)
static __inline__ void add_to_prot_sklist(struct sock *sk)
{
{
        SOCKHASH_LOCK();
        SOCKHASH_LOCK();
        if(!sk->sklist_next) {
        if(!sk->sklist_next) {
                struct proto *p = sk->prot;
                struct proto *p = sk->prot;
 
 
                sk->sklist_prev = (struct sock *) p;
                sk->sklist_prev = (struct sock *) p;
                sk->sklist_next = p->sklist_next;
                sk->sklist_next = p->sklist_next;
                p->sklist_next->sklist_prev = sk;
                p->sklist_next->sklist_prev = sk;
                p->sklist_next = sk;
                p->sklist_next = sk;
 
 
                /* Charge the protocol. */
                /* Charge the protocol. */
                sk->prot->inuse += 1;
                sk->prot->inuse += 1;
                if(sk->prot->highestinuse < sk->prot->inuse)
                if(sk->prot->highestinuse < sk->prot->inuse)
                        sk->prot->highestinuse = sk->prot->inuse;
                        sk->prot->highestinuse = sk->prot->inuse;
        }
        }
        SOCKHASH_UNLOCK();
        SOCKHASH_UNLOCK();
}
}
 
 
static __inline__ void del_from_prot_sklist(struct sock *sk)
static __inline__ void del_from_prot_sklist(struct sock *sk)
{
{
        SOCKHASH_LOCK();
        SOCKHASH_LOCK();
        if(sk->sklist_next) {
        if(sk->sklist_next) {
                sk->sklist_next->sklist_prev = sk->sklist_prev;
                sk->sklist_next->sklist_prev = sk->sklist_prev;
                sk->sklist_prev->sklist_next = sk->sklist_next;
                sk->sklist_prev->sklist_next = sk->sklist_next;
                sk->sklist_next = NULL;
                sk->sklist_next = NULL;
                sk->prot->inuse--;
                sk->prot->inuse--;
        }
        }
        SOCKHASH_UNLOCK();
        SOCKHASH_UNLOCK();
}
}
 
 
/*
/*
 * Used by processes to "lock" a socket state, so that
 * Used by processes to "lock" a socket state, so that
 * interrupts and bottom half handlers won't change it
 * interrupts and bottom half handlers won't change it
 * from under us. It essentially blocks any incoming
 * from under us. It essentially blocks any incoming
 * packets, so that we won't get any new data or any
 * packets, so that we won't get any new data or any
 * packets that change the state of the socket.
 * packets that change the state of the socket.
 *
 *
 * Note the 'barrier()' calls: gcc may not move a lock
 * Note the 'barrier()' calls: gcc may not move a lock
 * "downwards" or a unlock "upwards" when optimizing.
 * "downwards" or a unlock "upwards" when optimizing.
 */
 */
extern void __release_sock(struct sock *sk);
extern void __release_sock(struct sock *sk);
 
 
static inline void lock_sock(struct sock *sk)
static inline void lock_sock(struct sock *sk)
{
{
#if 0
#if 0
/* debugging code: the test isn't even 100% correct, but it can catch bugs */
/* debugging code: the test isn't even 100% correct, but it can catch bugs */
/* Note that a double lock is ok in theory - it's just _usually_ a bug */
/* Note that a double lock is ok in theory - it's just _usually_ a bug */
        if (sk->users) {
        if (sk->users) {
                __label__ here;
                __label__ here;
                printk("double lock on socket at %p\n", &&here);
                printk("double lock on socket at %p\n", &&here);
here:
here:
        }
        }
#endif
#endif
        sk->users++;
        sk->users++;
        barrier();
        barrier();
}
}
 
 
static inline void release_sock(struct sock *sk)
static inline void release_sock(struct sock *sk)
{
{
        barrier();
        barrier();
#if 0
#if 0
/* debugging code: remove me when ok */
/* debugging code: remove me when ok */
        if (sk->users == 0) {
        if (sk->users == 0) {
                __label__ here;
                __label__ here;
                sk->users = 1;
                sk->users = 1;
                printk("trying to unlock unlocked socket at %p\n", &&here);
                printk("trying to unlock unlocked socket at %p\n", &&here);
here:
here:
        }
        }
#endif
#endif
        if ((sk->users = sk->users-1) == 0)
        if ((sk->users = sk->users-1) == 0)
                __release_sock(sk);
                __release_sock(sk);
}
}
 
 
 
 
extern struct sock *            sk_alloc(int priority);
extern struct sock *            sk_alloc(int priority);
extern void                     sk_free(struct sock *sk);
extern void                     sk_free(struct sock *sk);
extern void                     destroy_sock(struct sock *sk);
extern void                     destroy_sock(struct sock *sk);
 
 
extern struct sk_buff           *sock_wmalloc(struct sock *sk,
extern struct sk_buff           *sock_wmalloc(struct sock *sk,
                                              unsigned long size, int force,
                                              unsigned long size, int force,
                                              int priority);
                                              int priority);
extern struct sk_buff           *sock_rmalloc(struct sock *sk,
extern struct sk_buff           *sock_rmalloc(struct sock *sk,
                                              unsigned long size, int force,
                                              unsigned long size, int force,
                                              int priority);
                                              int priority);
extern void                     sock_wfree(struct sock *sk,
extern void                     sock_wfree(struct sock *sk,
                                           struct sk_buff *skb);
                                           struct sk_buff *skb);
extern void                     sock_rfree(struct sock *sk,
extern void                     sock_rfree(struct sock *sk,
                                           struct sk_buff *skb);
                                           struct sk_buff *skb);
extern unsigned long            sock_rspace(struct sock *sk);
extern unsigned long            sock_rspace(struct sock *sk);
extern unsigned long            sock_wspace(struct sock *sk);
extern unsigned long            sock_wspace(struct sock *sk);
 
 
extern int                      sock_setsockopt(struct sock *sk, int level,
extern int                      sock_setsockopt(struct sock *sk, int level,
                                                int op, char *optval,
                                                int op, char *optval,
                                                int optlen);
                                                int optlen);
 
 
extern int                      sock_getsockopt(struct sock *sk, int level,
extern int                      sock_getsockopt(struct sock *sk, int level,
                                                int op, char *optval,
                                                int op, char *optval,
                                                int *optlen);
                                                int *optlen);
extern struct sk_buff           *sock_alloc_send_skb(struct sock *skb,
extern struct sk_buff           *sock_alloc_send_skb(struct sock *skb,
                                                     unsigned long size,
                                                     unsigned long size,
                                                     unsigned long fallback,
                                                     unsigned long fallback,
                                                     int noblock,
                                                     int noblock,
                                                     int *errcode);
                                                     int *errcode);
 
 
/*
/*
 *      Queue a received datagram if it will fit. Stream and sequenced
 *      Queue a received datagram if it will fit. Stream and sequenced
 *      protocols can't normally use this as they need to fit buffers in
 *      protocols can't normally use this as they need to fit buffers in
 *      and play with them.
 *      and play with them.
 *
 *
 *      Inlined as it's very short and called for pretty much every
 *      Inlined as it's very short and called for pretty much every
 *      packet ever received.
 *      packet ever received.
 */
 */
 
 
extern __inline__ int sock_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
extern __inline__ int sock_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
{
{
        if (sk->rmem_alloc + skb->truesize >= sk->rcvbuf)
        if (sk->rmem_alloc + skb->truesize >= sk->rcvbuf)
                return -ENOMEM;
                return -ENOMEM;
        atomic_add(skb->truesize, &sk->rmem_alloc);
        atomic_add(skb->truesize, &sk->rmem_alloc);
        skb->sk=sk;
        skb->sk=sk;
        skb_queue_tail(&sk->receive_queue,skb);
        skb_queue_tail(&sk->receive_queue,skb);
        if (!sk->dead)
        if (!sk->dead)
                sk->data_ready(sk,skb->len);
                sk->data_ready(sk,skb->len);
        return 0;
        return 0;
}
}
 
 
extern __inline__ int __sock_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
extern __inline__ int __sock_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
{
{
        if (sk->rmem_alloc + skb->truesize >= sk->rcvbuf)
        if (sk->rmem_alloc + skb->truesize >= sk->rcvbuf)
                return -ENOMEM;
                return -ENOMEM;
        atomic_add(skb->truesize, &sk->rmem_alloc);
        atomic_add(skb->truesize, &sk->rmem_alloc);
        skb->sk=sk;
        skb->sk=sk;
        __skb_queue_tail(&sk->receive_queue,skb);
        __skb_queue_tail(&sk->receive_queue,skb);
        if (!sk->dead)
        if (!sk->dead)
                sk->data_ready(sk,skb->len);
                sk->data_ready(sk,skb->len);
        return 0;
        return 0;
}
}
 
 
/*
/*
 *      Recover an error report and clear atomically
 *      Recover an error report and clear atomically
 */
 */
 
 
extern __inline__ int sock_error(struct sock *sk)
extern __inline__ int sock_error(struct sock *sk)
{
{
        int err=xchg(&sk->err,0);
        int err=xchg(&sk->err,0);
        return -err;
        return -err;
}
}
 
 
/*
/*
 *      Declarations from timer.c
 *      Declarations from timer.c
 */
 */
 
 
extern struct sock *timer_base;
extern struct sock *timer_base;
 
 
extern void delete_timer (struct sock *);
extern void delete_timer (struct sock *);
extern void reset_timer (struct sock *, int, unsigned long);
extern void reset_timer (struct sock *, int, unsigned long);
extern void net_timer (unsigned long);
extern void net_timer (unsigned long);
 
 
 
 
/*
/*
 *      Enable debug/info messages
 *      Enable debug/info messages
 */
 */
 
 
#define NETDEBUG(x)     do { } while (0)
#define NETDEBUG(x)     do { } while (0)
 
 
#endif  /* _SOCK_H */
#endif  /* _SOCK_H */
 
 

powered by: WebSVN 2.1.0

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