tipc: Reduce footprint by un-inlining nmap routines
[deliverable/linux.git] / net / tipc / bcast.h
CommitLineData
b97bf3fd
PL
1/*
2 * net/tipc/bcast.h: Include file for TIPC broadcast code
c4307285 3 *
9da1c8b6 4 * Copyright (c) 2003-2006, Ericsson AB
b97bf3fd 5 * Copyright (c) 2005, Wind River Systems
b97bf3fd
PL
6 * All rights reserved.
7 *
9ea1fd3c 8 * Redistribution and use in source and binary forms, with or without
b97bf3fd
PL
9 * modification, are permitted provided that the following conditions are met:
10 *
9ea1fd3c
PL
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 * 3. Neither the names of the copyright holders nor the names of its
17 * contributors may be used to endorse or promote products derived from
18 * this software without specific prior written permission.
b97bf3fd 19 *
9ea1fd3c
PL
20 * Alternatively, this software may be distributed under the terms of the
21 * GNU General Public License ("GPL") version 2 as published by the Free
22 * Software Foundation.
23 *
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
28 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
b97bf3fd
PL
34 * POSSIBILITY OF SUCH DAMAGE.
35 */
36
37#ifndef _TIPC_BCAST_H
38#define _TIPC_BCAST_H
39
40#define MAX_NODES 4096
41#define WSIZE 32
42
43/**
6c00055a 44 * struct tipc_node_map - set of node identifiers
b97bf3fd
PL
45 * @count: # of nodes in set
46 * @map: bitmap of node identifiers that are in the set
47 */
48
6c00055a 49struct tipc_node_map {
b97bf3fd
PL
50 u32 count;
51 u32 map[MAX_NODES / WSIZE];
52};
53
54
55#define PLSIZE 32
56
57/**
58 * struct port_list - set of node local destination ports
59 * @count: # of ports in set (only valid for first entry in list)
60 * @next: pointer to next entry in list
61 * @ports: array of port references
62 */
63
64struct port_list {
65 int count;
66 struct port_list *next;
67 u32 ports[PLSIZE];
68};
69
70
6c00055a 71struct tipc_node;
b97bf3fd 72
4b704d59 73extern const char tipc_bclink_name[];
b97bf3fd 74
3e22e62b
AS
75void tipc_nmap_add(struct tipc_node_map *nm_ptr, u32 node);
76void tipc_nmap_remove(struct tipc_node_map *nm_ptr, u32 node);
b97bf3fd
PL
77
78/**
c68ca7b7 79 * tipc_nmap_equal - test for equality of node maps
b97bf3fd
PL
80 */
81
6c00055a 82static inline int tipc_nmap_equal(struct tipc_node_map *nm_a, struct tipc_node_map *nm_b)
b97bf3fd
PL
83{
84 return !memcmp(nm_a, nm_b, sizeof(*nm_a));
85}
86
3e22e62b
AS
87void tipc_nmap_diff(struct tipc_node_map *nm_a, struct tipc_node_map *nm_b,
88 struct tipc_node_map *nm_diff);
b97bf3fd
PL
89
90/**
c68ca7b7 91 * tipc_port_list_add - add a port to a port list, ensuring no duplicates
b97bf3fd
PL
92 */
93
4323add6 94static inline void tipc_port_list_add(struct port_list *pl_ptr, u32 port)
b97bf3fd
PL
95{
96 struct port_list *item = pl_ptr;
97 int i;
98 int item_sz = PLSIZE;
99 int cnt = pl_ptr->count;
100
101 for (; ; cnt -= item_sz, item = item->next) {
102 if (cnt < PLSIZE)
103 item_sz = cnt;
104 for (i = 0; i < item_sz; i++)
105 if (item->ports[i] == port)
106 return;
107 if (i < PLSIZE) {
108 item->ports[i] = port;
109 pl_ptr->count++;
110 return;
111 }
112 if (!item->next) {
113 item->next = kmalloc(sizeof(*item), GFP_ATOMIC);
114 if (!item->next) {
a10bd924 115 warn("Incomplete multicast delivery, no memory\n");
b97bf3fd
PL
116 return;
117 }
118 item->next->next = NULL;
119 }
120 }
121}
122
123/**
c68ca7b7 124 * tipc_port_list_free - free dynamically created entries in port_list chain
c4307285 125 *
b97bf3fd
PL
126 * Note: First item is on stack, so it doesn't need to be released
127 */
128
4323add6 129static inline void tipc_port_list_free(struct port_list *pl_ptr)
b97bf3fd
PL
130{
131 struct port_list *item;
132 struct port_list *next;
133
134 for (item = pl_ptr->next; item; item = next) {
135 next = item->next;
136 kfree(item);
137 }
138}
139
140
4323add6
PL
141int tipc_bclink_init(void);
142void tipc_bclink_stop(void);
6c00055a 143void tipc_bclink_acknowledge(struct tipc_node *n_ptr, u32 acked);
4323add6
PL
144int tipc_bclink_send_msg(struct sk_buff *buf);
145void tipc_bclink_recv_pkt(struct sk_buff *buf);
146u32 tipc_bclink_get_last_sent(void);
6c00055a
DM
147u32 tipc_bclink_acks_missing(struct tipc_node *n_ptr);
148void tipc_bclink_check_gap(struct tipc_node *n_ptr, u32 seqno);
4323add6
PL
149int tipc_bclink_stats(char *stats_buf, const u32 buf_size);
150int tipc_bclink_reset_stats(void);
151int tipc_bclink_set_queue_limits(u32 limit);
152void tipc_bcbearer_sort(void);
153void tipc_bcbearer_push(void);
b97bf3fd
PL
154
155#endif
This page took 0.400169 seconds and 5 git commands to generate.