This source file includes following definitions.
- loopback_xmit
- get_stats
- loopback_open
- loopback_init
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23 #include <linux/config.h>
24 #include <linux/kernel.h>
25 #include <linux/sched.h>
26 #include <linux/interrupt.h>
27 #include <linux/fs.h>
28 #include <linux/types.h>
29 #include <linux/string.h>
30 #include <linux/socket.h>
31 #include <linux/errno.h>
32 #include <linux/fcntl.h>
33 #include <linux/in.h>
34 #include <linux/if_ether.h>
35
36 #include <asm/system.h>
37 #include <asm/segment.h>
38 #include <asm/io.h>
39
40 #include <linux/inet.h>
41 #include <linux/netdevice.h>
42 #include <linux/etherdevice.h>
43 #include <linux/skbuff.h>
44 #include <net/sock.h>
45
46
47 static int loopback_xmit(struct sk_buff *skb, struct device *dev)
48 {
49 struct enet_statistics *stats = (struct enet_statistics *)dev->priv;
50 unsigned long flags;
51 int unlock=1;
52
53 if (skb == NULL || dev == NULL)
54 return(0);
55
56 save_flags(flags);
57 cli();
58 if (dev->tbusy != 0)
59 {
60 restore_flags(flags);
61 stats->tx_errors++;
62 return(1);
63 }
64 dev->tbusy = 1;
65 restore_flags(flags);
66
67
68
69
70
71
72 if(skb->free==0)
73 {
74 struct sk_buff *skb2=skb;
75 skb=skb_clone(skb, GFP_ATOMIC);
76 if(skb==NULL)
77 return 1;
78 dev_kfree_skb(skb2, FREE_READ);
79 unlock=0;
80 }
81 else if(skb->sk)
82 {
83
84
85
86
87 save_flags(flags);
88 cli();
89 skb->sk->wmem_alloc-=skb->truesize;
90 skb->sk->write_space(skb->sk);
91 restore_flags(flags);
92 }
93
94 skb->protocol=eth_type_trans(skb,dev);
95 skb->dev=dev;
96 save_flags(flags);
97 cli();
98 netif_rx(skb);
99 if(unlock)
100 skb_device_unlock(skb);
101 restore_flags(flags);
102
103 stats->tx_packets++;
104 stats->rx_packets++;
105
106 dev->tbusy = 0;
107
108 return(0);
109 }
110
111 static struct enet_statistics *get_stats(struct device *dev)
112 {
113 return (struct enet_statistics *)dev->priv;
114 }
115
116 static int loopback_open(struct device *dev)
117 {
118 dev->flags|=IFF_LOOPBACK;
119 return 0;
120 }
121
122
123 int loopback_init(struct device *dev)
124 {
125 int i;
126
127 dev->mtu = 2000;
128 dev->tbusy = 0;
129 dev->hard_start_xmit = loopback_xmit;
130 dev->open = NULL;
131 dev->hard_header = eth_header;
132 dev->hard_header_len = ETH_HLEN;
133 dev->addr_len = ETH_ALEN;
134 dev->type = ARPHRD_ETHER;
135 dev->rebuild_header = eth_rebuild_header;
136 dev->open = loopback_open;
137 dev->flags = IFF_LOOPBACK|IFF_BROADCAST;
138 dev->family = AF_INET;
139 #ifdef CONFIG_INET
140 dev->pa_addr = in_aton("127.0.0.1");
141 dev->pa_brdaddr = in_aton("127.255.255.255");
142 dev->pa_mask = in_aton("255.0.0.0");
143 dev->pa_alen = 4;
144 #endif
145 dev->priv = kmalloc(sizeof(struct enet_statistics), GFP_KERNEL);
146 memset(dev->priv, 0, sizeof(struct enet_statistics));
147 dev->get_stats = get_stats;
148
149
150
151
152
153 for (i = 0; i < DEV_NUMBUFFS; i++)
154 skb_queue_head_init(&dev->buffs[i]);
155
156 return(0);
157 };