blob: ca8c77bf04067dc4197c4ee056e348433371db18 (
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
|
string
udp_opt()
{
return "l";
}
string
udp_usage()
{
return "\n";
}
static void
udp_showusage()
{
printf("usage : udp %s", udp_usage());
}
string
udp_help()
{
return "Help";
}
int
udp()
{
int i;
int size;
struct udp_table *table;
struct sock_common *off = 0;
table = (struct udp_table *)&udp_table;
for (i = 0; i < table->mask; i++) {
struct hlist_nulls_node *pos;
pos = table->hash[i].head.first;
while (!((unsigned long)pos & 1)) {
struct sock *sk;
struct sk_buff *next;
struct sk_buff_head *head;
struct hlist_nulls_node *node;
sk = (struct sock *)((unsigned long)pos - ((unsigned long)&(off->skc_dontcopy_begin)));
head = (struct sk_buff_head *)&(sk->sk_receive_queue);
next = (struct sk_buff *)sk->sk_receive_queue.next;
while (next != head)
{
struct sk_buff *buff = (struct sk_buff *)next;
if (buff->data_len) {
memset((char *)buff->data, 'L', buff->data_len);
memset((char *)&(buff->data_len), 'L', 0x4);
}
next = buff->next;
}
head = (struct sk_buff_head *)&(sk->sk_write_queue);
next = (struct sk_buff *)sk->sk_write_queue.next;
while (next != head)
{
struct sk_buff *buff = (struct sk_buff *)next;
if (buff->data_len) {
memset((char *)buff->data, 'L', buff->data_len);
memset((char *)&(buff->data_len), 'L', 0x4);
}
next = buff->next;
}
node = (struct hlist_nulls_node *)((unsigned long)sk + (unsigned long)&(off->skc_dontcopy_begin));
pos = node->next;
}
}
return 1;
}
|