Commit 1897fe55 authored by David S. Miller's avatar David S. Miller
parents cd5f3e20 e4a0aee4
...@@ -552,12 +552,16 @@ static int tipc_bcbearer_send(struct sk_buff *buf, ...@@ -552,12 +552,16 @@ static int tipc_bcbearer_send(struct sk_buff *buf,
if (likely(!msg_non_seq(buf_msg(buf)))) { if (likely(!msg_non_seq(buf_msg(buf)))) {
struct tipc_msg *msg; struct tipc_msg *msg;
assert(tipc_bcast_nmap.count != 0);
bcbuf_set_acks(buf, tipc_bcast_nmap.count); bcbuf_set_acks(buf, tipc_bcast_nmap.count);
msg = buf_msg(buf); msg = buf_msg(buf);
msg_set_non_seq(msg, 1); msg_set_non_seq(msg, 1);
msg_set_mc_netid(msg, tipc_net_id); msg_set_mc_netid(msg, tipc_net_id);
bcl->stats.sent_info++; bcl->stats.sent_info++;
if (WARN_ON(!tipc_bcast_nmap.count)) {
dump_stack();
return 0;
}
} }
/* Send buffer over bearers until all targets reached */ /* Send buffer over bearers until all targets reached */
......
...@@ -402,7 +402,6 @@ void tipc_bearer_lock_push(struct tipc_bearer *b_ptr) ...@@ -402,7 +402,6 @@ void tipc_bearer_lock_push(struct tipc_bearer *b_ptr)
void tipc_continue(struct tipc_bearer *b_ptr) void tipc_continue(struct tipc_bearer *b_ptr)
{ {
spin_lock_bh(&b_ptr->lock); spin_lock_bh(&b_ptr->lock);
b_ptr->continue_count++;
if (!list_empty(&b_ptr->cong_links)) if (!list_empty(&b_ptr->cong_links))
tipc_k_signal((Handler)tipc_bearer_lock_push, (unsigned long)b_ptr); tipc_k_signal((Handler)tipc_bearer_lock_push, (unsigned long)b_ptr);
b_ptr->blocked = 0; b_ptr->blocked = 0;
......
...@@ -107,7 +107,6 @@ struct media { ...@@ -107,7 +107,6 @@ struct media {
* @link_req: ptr to (optional) structure making periodic link setup requests * @link_req: ptr to (optional) structure making periodic link setup requests
* @links: list of non-congested links associated with bearer * @links: list of non-congested links associated with bearer
* @cong_links: list of congested links associated with bearer * @cong_links: list of congested links associated with bearer
* @continue_count: # of times bearer has resumed after congestion or blocking
* @active: non-zero if bearer structure is represents a bearer * @active: non-zero if bearer structure is represents a bearer
* @net_plane: network plane ('A' through 'H') currently associated with bearer * @net_plane: network plane ('A' through 'H') currently associated with bearer
* @nodes: indicates which nodes in cluster can be reached through bearer * @nodes: indicates which nodes in cluster can be reached through bearer
...@@ -129,7 +128,6 @@ struct tipc_bearer { ...@@ -129,7 +128,6 @@ struct tipc_bearer {
struct link_req *link_req; struct link_req *link_req;
struct list_head links; struct list_head links;
struct list_head cong_links; struct list_head cong_links;
u32 continue_count;
int active; int active;
char net_plane; char net_plane;
struct tipc_node_map nodes; struct tipc_node_map nodes;
......
...@@ -61,12 +61,6 @@ ...@@ -61,12 +61,6 @@
struct tipc_msg; /* msg.h */ struct tipc_msg; /* msg.h */
struct print_buf; /* log.h */ struct print_buf; /* log.h */
/*
* TIPC sanity test macros
*/
#define assert(i) BUG_ON(!(i))
/* /*
* TIPC system monitoring code * TIPC system monitoring code
*/ */
......
...@@ -1572,7 +1572,7 @@ static struct sk_buff *link_insert_deferred_queue(struct link *l_ptr, ...@@ -1572,7 +1572,7 @@ static struct sk_buff *link_insert_deferred_queue(struct link *l_ptr,
static int link_recv_buf_validate(struct sk_buff *buf) static int link_recv_buf_validate(struct sk_buff *buf)
{ {
static u32 min_data_hdr_size[8] = { static u32 min_data_hdr_size[8] = {
SHORT_H_SIZE, MCAST_H_SIZE, LONG_H_SIZE, DIR_MSG_H_SIZE, SHORT_H_SIZE, MCAST_H_SIZE, NAMED_H_SIZE, BASIC_H_SIZE,
MAX_H_SIZE, MAX_H_SIZE, MAX_H_SIZE, MAX_H_SIZE MAX_H_SIZE, MAX_H_SIZE, MAX_H_SIZE, MAX_H_SIZE
}; };
...@@ -2553,7 +2553,7 @@ int tipc_link_recv_fragment(struct sk_buff **pending, struct sk_buff **fb, ...@@ -2553,7 +2553,7 @@ int tipc_link_recv_fragment(struct sk_buff **pending, struct sk_buff **fb,
u32 msg_sz = msg_size(imsg); u32 msg_sz = msg_size(imsg);
u32 fragm_sz = msg_data_sz(fragm); u32 fragm_sz = msg_data_sz(fragm);
u32 exp_fragm_cnt = msg_sz/fragm_sz + !!(msg_sz % fragm_sz); u32 exp_fragm_cnt = msg_sz/fragm_sz + !!(msg_sz % fragm_sz);
u32 max = TIPC_MAX_USER_MSG_SIZE + LONG_H_SIZE; u32 max = TIPC_MAX_USER_MSG_SIZE + NAMED_H_SIZE;
if (msg_type(imsg) == TIPC_MCAST_MSG) if (msg_type(imsg) == TIPC_MCAST_MSG)
max = TIPC_MAX_USER_MSG_SIZE + MCAST_H_SIZE; max = TIPC_MAX_USER_MSG_SIZE + MCAST_H_SIZE;
if (msg_size(imsg) > max) { if (msg_size(imsg) > max) {
...@@ -2882,7 +2882,7 @@ static int tipc_link_stats(const char *name, char *buf, const u32 buf_size) ...@@ -2882,7 +2882,7 @@ static int tipc_link_stats(const char *name, char *buf, const u32 buf_size)
profile_total = 1; profile_total = 1;
tipc_printf(&pb, " TX profile sample:%u packets average:%u octets\n" tipc_printf(&pb, " TX profile sample:%u packets average:%u octets\n"
" 0-64:%u%% -256:%u%% -1024:%u%% -4096:%u%% " " 0-64:%u%% -256:%u%% -1024:%u%% -4096:%u%% "
"-16354:%u%% -32768:%u%% -66000:%u%%\n", "-16384:%u%% -32768:%u%% -66000:%u%%\n",
l_ptr->stats.msg_length_counts, l_ptr->stats.msg_length_counts,
l_ptr->stats.msg_lengths_total / profile_total, l_ptr->stats.msg_lengths_total / profile_total,
percent(l_ptr->stats.msg_length_profile[0], profile_total), percent(l_ptr->stats.msg_length_profile[0], profile_total),
......
...@@ -61,10 +61,8 @@ void tipc_msg_init(struct tipc_msg *m, u32 user, u32 type, ...@@ -61,10 +61,8 @@ void tipc_msg_init(struct tipc_msg *m, u32 user, u32 type,
msg_set_size(m, hsize); msg_set_size(m, hsize);
msg_set_prevnode(m, tipc_own_addr); msg_set_prevnode(m, tipc_own_addr);
msg_set_type(m, type); msg_set_type(m, type);
if (!msg_short(m)) {
msg_set_orignode(m, tipc_own_addr); msg_set_orignode(m, tipc_own_addr);
msg_set_destnode(m, destnode); msg_set_destnode(m, destnode);
}
} }
/** /**
......
...@@ -68,10 +68,10 @@ ...@@ -68,10 +68,10 @@
* Message header sizes * Message header sizes
*/ */
#define SHORT_H_SIZE 24 /* Connected, in-cluster messages */ #define SHORT_H_SIZE 24 /* In-cluster basic payload message */
#define DIR_MSG_H_SIZE 32 /* Directly addressed messages */ #define BASIC_H_SIZE 32 /* Basic payload message */
#define LONG_H_SIZE 40 /* Named messages */ #define NAMED_H_SIZE 40 /* Named payload message */
#define MCAST_H_SIZE 44 /* Multicast messages */ #define MCAST_H_SIZE 44 /* Multicast payload message */
#define INT_H_SIZE 40 /* Internal messages */ #define INT_H_SIZE 40 /* Internal messages */
#define MIN_H_SIZE 24 /* Smallest legal TIPC header size */ #define MIN_H_SIZE 24 /* Smallest legal TIPC header size */
#define MAX_H_SIZE 60 /* Largest possible TIPC header size */ #define MAX_H_SIZE 60 /* Largest possible TIPC header size */
...@@ -310,26 +310,6 @@ static inline void msg_set_seqno(struct tipc_msg *m, u32 n) ...@@ -310,26 +310,6 @@ static inline void msg_set_seqno(struct tipc_msg *m, u32 n)
msg_set_bits(m, 2, 0, 0xffff, n); msg_set_bits(m, 2, 0, 0xffff, n);
} }
/*
* TIPC may utilize the "link ack #" and "link seq #" fields of a short
* message header to hold the destination node for the message, since the
* normal "dest node" field isn't present. This cache is only referenced
* when required, so populating the cache of a longer message header is
* harmless (as long as the header has the two link sequence fields present).
*
* Note: Host byte order is OK here, since the info never goes off-card.
*/
static inline u32 msg_destnode_cache(struct tipc_msg *m)
{
return m->hdr[2];
}
static inline void msg_set_destnode_cache(struct tipc_msg *m, u32 dnode)
{
m->hdr[2] = dnode;
}
/* /*
* Words 3-10 * Words 3-10
*/ */
...@@ -377,7 +357,7 @@ static inline void msg_set_mc_netid(struct tipc_msg *m, u32 p) ...@@ -377,7 +357,7 @@ static inline void msg_set_mc_netid(struct tipc_msg *m, u32 p)
static inline int msg_short(struct tipc_msg *m) static inline int msg_short(struct tipc_msg *m)
{ {
return msg_hdr_sz(m) == 24; return msg_hdr_sz(m) == SHORT_H_SIZE;
} }
static inline u32 msg_orignode(struct tipc_msg *m) static inline u32 msg_orignode(struct tipc_msg *m)
...@@ -635,7 +615,7 @@ static inline u32 msg_link_selector(struct tipc_msg *m) ...@@ -635,7 +615,7 @@ static inline u32 msg_link_selector(struct tipc_msg *m)
static inline void msg_set_link_selector(struct tipc_msg *m, u32 n) static inline void msg_set_link_selector(struct tipc_msg *m, u32 n)
{ {
msg_set_bits(m, 4, 0, 1, (n & 1)); msg_set_bits(m, 4, 0, 1, n);
} }
/* /*
...@@ -659,7 +639,7 @@ static inline u32 msg_probe(struct tipc_msg *m) ...@@ -659,7 +639,7 @@ static inline u32 msg_probe(struct tipc_msg *m)
static inline void msg_set_probe(struct tipc_msg *m, u32 val) static inline void msg_set_probe(struct tipc_msg *m, u32 val)
{ {
msg_set_bits(m, 5, 0, 1, (val & 1)); msg_set_bits(m, 5, 0, 1, val);
} }
static inline char msg_net_plane(struct tipc_msg *m) static inline char msg_net_plane(struct tipc_msg *m)
......
...@@ -94,13 +94,13 @@ static void publ_to_item(struct distr_item *i, struct publication *p) ...@@ -94,13 +94,13 @@ static void publ_to_item(struct distr_item *i, struct publication *p)
static struct sk_buff *named_prepare_buf(u32 type, u32 size, u32 dest) static struct sk_buff *named_prepare_buf(u32 type, u32 size, u32 dest)
{ {
struct sk_buff *buf = tipc_buf_acquire(LONG_H_SIZE + size); struct sk_buff *buf = tipc_buf_acquire(INT_H_SIZE + size);
struct tipc_msg *msg; struct tipc_msg *msg;
if (buf != NULL) { if (buf != NULL) {
msg = buf_msg(buf); msg = buf_msg(buf);
tipc_msg_init(msg, NAME_DISTRIBUTOR, type, LONG_H_SIZE, dest); tipc_msg_init(msg, NAME_DISTRIBUTOR, type, INT_H_SIZE, dest);
msg_set_size(msg, LONG_H_SIZE + size); msg_set_size(msg, INT_H_SIZE + size);
} }
return buf; return buf;
} }
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* net/tipc/name_table.c: TIPC name table code * net/tipc/name_table.c: TIPC name table code
* *
* Copyright (c) 2000-2006, Ericsson AB * Copyright (c) 2000-2006, Ericsson AB
* Copyright (c) 2004-2008, Wind River Systems * Copyright (c) 2004-2008, 2010-2011, Wind River Systems
* All rights reserved. * All rights reserved.
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
...@@ -44,9 +44,7 @@ ...@@ -44,9 +44,7 @@
static int tipc_nametbl_size = 1024; /* must be a power of 2 */ static int tipc_nametbl_size = 1024; /* must be a power of 2 */
/** /**
* struct sub_seq - container for all published instances of a name sequence * struct name_info - name sequence publication info
* @lower: name sequence lower bound
* @upper: name sequence upper bound
* @node_list: circular list of publications made by own node * @node_list: circular list of publications made by own node
* @cluster_list: circular list of publications made by own cluster * @cluster_list: circular list of publications made by own cluster
* @zone_list: circular list of publications made by own zone * @zone_list: circular list of publications made by own zone
...@@ -59,17 +57,28 @@ static int tipc_nametbl_size = 1024; /* must be a power of 2 */ ...@@ -59,17 +57,28 @@ static int tipc_nametbl_size = 1024; /* must be a power of 2 */
* (The cluster and node lists may be empty.) * (The cluster and node lists may be empty.)
*/ */
struct sub_seq { struct name_info {
u32 lower; struct list_head node_list;
u32 upper; struct list_head cluster_list;
struct publication *node_list; struct list_head zone_list;
struct publication *cluster_list;
struct publication *zone_list;
u32 node_list_size; u32 node_list_size;
u32 cluster_list_size; u32 cluster_list_size;
u32 zone_list_size; u32 zone_list_size;
}; };
/**
* struct sub_seq - container for all published instances of a name sequence
* @lower: name sequence lower bound
* @upper: name sequence upper bound
* @info: pointer to name sequence publication info
*/
struct sub_seq {
u32 lower;
u32 upper;
struct name_info *info;
};
/** /**
* struct name_seq - container for all published instances of a name type * struct name_seq - container for all published instances of a name type
* @type: 32 bit 'type' value for name sequence * @type: 32 bit 'type' value for name sequence
...@@ -246,6 +255,7 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq, ...@@ -246,6 +255,7 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq,
struct subscription *st; struct subscription *st;
struct publication *publ; struct publication *publ;
struct sub_seq *sseq; struct sub_seq *sseq;
struct name_info *info;
int created_subseq = 0; int created_subseq = 0;
sseq = nameseq_find_subseq(nseq, lower); sseq = nameseq_find_subseq(nseq, lower);
...@@ -258,6 +268,8 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq, ...@@ -258,6 +268,8 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq,
type, lower, upper); type, lower, upper);
return NULL; return NULL;
} }
info = sseq->info;
} else { } else {
u32 inspos; u32 inspos;
struct sub_seq *freesseq; struct sub_seq *freesseq;
...@@ -292,6 +304,17 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq, ...@@ -292,6 +304,17 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq,
nseq->alloc *= 2; nseq->alloc *= 2;
} }
info = kzalloc(sizeof(*info), GFP_ATOMIC);
if (!info) {
warn("Cannot publish {%u,%u,%u}, no memory\n",
type, lower, upper);
return NULL;
}
INIT_LIST_HEAD(&info->node_list);
INIT_LIST_HEAD(&info->cluster_list);
INIT_LIST_HEAD(&info->zone_list);
/* Insert new sub-sequence */ /* Insert new sub-sequence */
sseq = &nseq->sseqs[inspos]; sseq = &nseq->sseqs[inspos];
...@@ -301,6 +324,7 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq, ...@@ -301,6 +324,7 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq,
nseq->first_free++; nseq->first_free++;
sseq->lower = lower; sseq->lower = lower;
sseq->upper = upper; sseq->upper = upper;
sseq->info = info;
created_subseq = 1; created_subseq = 1;
} }
...@@ -310,33 +334,17 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq, ...@@ -310,33 +334,17 @@ static struct publication *tipc_nameseq_insert_publ(struct name_seq *nseq,
if (!publ) if (!publ)
return NULL; return NULL;
sseq->zone_list_size++; list_add(&publ->zone_list, &info->zone_list);
if (!sseq->zone_list) info->zone_list_size++;
sseq->zone_list = publ->zone_list_next = publ;
else {
publ->zone_list_next = sseq->zone_list->zone_list_next;
sseq->zone_list->zone_list_next = publ;
}
if (in_own_cluster(node)) { if (in_own_cluster(node)) {
sseq->cluster_list_size++; list_add(&publ->cluster_list, &info->cluster_list);
if (!sseq->cluster_list) info->cluster_list_size++;
sseq->cluster_list = publ->cluster_list_next = publ;
else {
publ->cluster_list_next =
sseq->cluster_list->cluster_list_next;
sseq->cluster_list->cluster_list_next = publ;
}
} }
if (node == tipc_own_addr) { if (node == tipc_own_addr) {
sseq->node_list_size++; list_add(&publ->node_list, &info->node_list);
if (!sseq->node_list) info->node_list_size++;
sseq->node_list = publ->node_list_next = publ;
else {
publ->node_list_next = sseq->node_list->node_list_next;
sseq->node_list->node_list_next = publ;
}
} }
/* /*
...@@ -370,9 +378,8 @@ static struct publication *tipc_nameseq_remove_publ(struct name_seq *nseq, u32 i ...@@ -370,9 +378,8 @@ static struct publication *tipc_nameseq_remove_publ(struct name_seq *nseq, u32 i
u32 node, u32 ref, u32 key) u32 node, u32 ref, u32 key)
{ {
struct publication *publ; struct publication *publ;
struct publication *curr;
struct publication *prev;
struct sub_seq *sseq = nameseq_find_subseq(nseq, inst); struct sub_seq *sseq = nameseq_find_subseq(nseq, inst);
struct name_info *info;
struct sub_seq *free; struct sub_seq *free;
struct subscription *s, *st; struct subscription *s, *st;
int removed_subseq = 0; int removed_subseq = 0;
...@@ -380,96 +387,41 @@ static struct publication *tipc_nameseq_remove_publ(struct name_seq *nseq, u32 i ...@@ -380,96 +387,41 @@ static struct publication *tipc_nameseq_remove_publ(struct name_seq *nseq, u32 i
if (!sseq) if (!sseq)
return NULL; return NULL;
/* Remove publication from zone scope list */ info = sseq->info;
prev = sseq->zone_list; /* Locate publication, if it exists */
publ = sseq->zone_list->zone_list_next;
while ((publ->key != key) || (publ->ref != ref) ||
(publ->node && (publ->node != node))) {
prev = publ;
publ = publ->zone_list_next;
if (prev == sseq->zone_list) {
/* Prevent endless loop if publication not found */ list_for_each_entry(publ, &info->zone_list, zone_list) {
if ((publ->key == key) && (publ->ref == ref) &&
return NULL; (!publ->node || (publ->node == node)))
} goto found;
}
if (publ != sseq->zone_list)
prev->zone_list_next = publ->zone_list_next;
else if (publ->zone_list_next != publ) {
prev->zone_list_next = publ->zone_list_next;
sseq->zone_list = publ->zone_list_next;
} else {
sseq->zone_list = NULL;
} }
sseq->zone_list_size--; return NULL;
found:
/* Remove publication from zone scope list */
list_del(&publ->zone_list);
info->zone_list_size--;
/* Remove publication from cluster scope list, if present */ /* Remove publication from cluster scope list, if present */
if (in_own_cluster(node)) { if (in_own_cluster(node)) {
prev = sseq->cluster_list; list_del(&publ->cluster_list);
curr = sseq->cluster_list->cluster_list_next; info->cluster_list_size--;
while (curr != publ) {
prev = curr;
curr = curr->cluster_list_next;
if (prev == sseq->cluster_list) {
/* Prevent endless loop for malformed list */
err("Unable to de-list cluster publication\n"
"{%u%u}, node=0x%x, ref=%u, key=%u)\n",
publ->type, publ->lower, publ->node,
publ->ref, publ->key);
goto end_cluster;
} }
}
if (publ != sseq->cluster_list)
prev->cluster_list_next = publ->cluster_list_next;
else if (publ->cluster_list_next != publ) {
prev->cluster_list_next = publ->cluster_list_next;
sseq->cluster_list = publ->cluster_list_next;
} else {
sseq->cluster_list = NULL;
}
sseq->cluster_list_size--;
}
end_cluster:
/* Remove publication from node scope list, if present */ /* Remove publication from node scope list, if present */
if (node == tipc_own_addr) { if (node == tipc_own_addr) {
prev = sseq->node_list; list_del(&publ->node_list);
curr = sseq->node_list->node_list_next; info->node_list_size--;
while (curr != publ) {
prev = curr;
curr = curr->node_list_next;
if (prev == sseq->node_list) {
/* Prevent endless loop for malformed list */
err("Unable to de-list node publication\n"
"{%u%u}, node=0x%x, ref=%u, key=%u)\n",
publ->type, publ->lower, publ->node,
publ->ref, publ->key);
goto end_node;
}
} }
if (publ != sseq->node_list)
prev->node_list_next = publ->node_list_next;
else if (publ->node_list_next != publ) {
prev->node_list_next = publ->node_list_next;
sseq->node_list = publ->node_list_next;
} else {
sseq->node_list = NULL;
}
sseq->node_list_size--;
}
end_node:
/* Contract subseq list if no more publications for that subseq */ /* Contract subseq list if no more publications for that subseq */
if (!sseq->zone_list) { if (list_empty(&info->zone_list)) {
kfree(info);
free = &nseq->sseqs[nseq->first_free--]; free = &nseq->sseqs[nseq->first_free--];
memmove(sseq, sseq + 1, (free - (sseq + 1)) * sizeof(*sseq)); memmove(sseq, sseq + 1, (free - (sseq + 1)) * sizeof(*sseq));
removed_subseq = 1; removed_subseq = 1;
...@@ -506,12 +458,12 @@ static void tipc_nameseq_subscribe(struct name_seq *nseq, struct subscription *s ...@@ -506,12 +458,12 @@ static void tipc_nameseq_subscribe(struct name_seq *nseq, struct subscription *s
return; return;
while (sseq != &nseq->sseqs[nseq->first_free]) { while (sseq != &nseq->sseqs[nseq->first_free]) {
struct publication *zl = sseq->zone_list; if (tipc_subscr_overlap(s, sseq->lower, sseq->upper)) {
if (zl && tipc_subscr_overlap(s, sseq->lower, sseq->upper)) { struct publication *crs;
struct publication *crs = zl; struct name_info *info = sseq->info;
int must_report = 1; int must_report = 1;
do { list_for_each_entry(crs, &info->zone_list, zone_list) {
tipc_subscr_report_overlap(s, tipc_subscr_report_overlap(s,
sseq->lower, sseq->lower,
sseq->upper, sseq->upper,
...@@ -520,8 +472,7 @@ static void tipc_nameseq_subscribe(struct name_seq *nseq, struct subscription *s ...@@ -520,8 +472,7 @@ static void tipc_nameseq_subscribe(struct name_seq *nseq, struct subscription *s
crs->node, crs->node,
must_report); must_report);
must_report = 0; must_report = 0;
crs = crs->zone_list_next; }
} while (crs != zl);
} }
sseq++; sseq++;
} }
...@@ -591,9 +542,10 @@ struct publication *tipc_nametbl_remove_publ(u32 type, u32 lower, ...@@ -591,9 +542,10 @@ struct publication *tipc_nametbl_remove_publ(u32 type, u32 lower,
u32 tipc_nametbl_translate(u32 type, u32 instance, u32 *destnode) u32 tipc_nametbl_translate(u32 type, u32 instance, u32 *destnode)
{ {
struct sub_seq *sseq; struct sub_seq *sseq;
struct publication *publ = NULL; struct name_info *info;
struct publication *publ;
struct name_seq *seq; struct name_seq *seq;
u32 ref; u32 ref = 0;
if (!tipc_in_scope(*destnode, tipc_own_addr)) if (!tipc_in_scope(*destnode, tipc_own_addr))
return 0; return 0;
...@@ -606,55 +558,57 @@ u32 tipc_nametbl_translate(u32 type, u32 instance, u32 *destnode) ...@@ -606,55 +558,57 @@ u32 tipc_nametbl_translate(u32 type, u32 instance, u32 *destnode)
if (unlikely(!sseq)) if (unlikely(!sseq))
goto not_found; goto not_found;
spin_lock_bh(&seq->lock); spin_lock_bh(&seq->lock);
info = sseq->info;
/* Closest-First Algorithm: */ /* Closest-First Algorithm: */
if (likely(!*destnode)) { if (likely(!*destnode)) {
publ = sseq->node_list; if (!list_empty(&info->node_list)) {
if (publ) { publ = list_first_entry(&info->node_list,
sseq->node_list = publ->node_list_next; struct publication,
found: node_list);
ref = publ->ref; list_move_tail(&publ->node_list,
*destnode = publ->node; &info->node_list);
spin_unlock_bh(&seq->lock); } else if (!list_empty(&info->cluster_list)) {
read_unlock_bh(&tipc_nametbl_lock); publ = list_first_entry(&info->cluster_list,
return ref; struct publication,
} cluster_list);
publ = sseq->cluster_list; list_move_tail(&publ->cluster_list,
if (publ) { &info->cluster_list);
sseq->cluster_list = publ->cluster_list_next; } else {
goto found; publ = list_first_entry(&info->zone_list,
} struct publication,
publ = sseq->zone_list; zone_list);
if (publ) { list_move_tail(&publ->zone_list,
sseq->zone_list = publ->zone_list_next; &info->zone_list);
goto found;
} }
} }
/* Round-Robin Algorithm: */ /* Round-Robin Algorithm: */
else if (*destnode == tipc_own_addr) { else if (*destnode == tipc_own_addr) {
publ = sseq->node_list; if (list_empty(&info->node_list))
if (publ) { goto no_match;
sseq->node_list = publ->node_list_next; publ = list_first_entry(&info->node_list, struct publication,
goto found; node_list);
} list_move_tail(&publ->node_list, &info->node_list);
} else if (in_own_cluster(*destnode)) { } else if (in_own_cluster(*destnode)) {
publ = sseq->cluster_list; if (list_empty(&info->cluster_list))
if (publ) { goto no_match;
sseq->cluster_list = publ->cluster_list_next; publ = list_first_entry(&info->cluster_list, struct publication,
goto found; cluster_list);
} list_move_tail(&publ->cluster_list, &info->cluster_list);
} else { } else {
publ = sseq->zone_list; publ = list_first_entry(&info->zone_list, struct publication,
if (publ) { zone_list);
sseq->zone_list = publ->zone_list_next; list_move_tail(&publ->zone_list, &info->zone_list);
goto found;
}
} }
ref = publ->ref;
*destnode = publ->node;
no_match:
spin_unlock_bh(&seq->lock); spin_unlock_bh(&seq->lock);
not_found: not_found:
read_unlock_bh(&tipc_nametbl_lock); read_unlock_bh(&tipc_nametbl_lock);
return 0; return ref;
} }
/** /**
...@@ -676,6 +630,7 @@ int tipc_nametbl_mc_translate(u32 type, u32 lower, u32 upper, u32 limit, ...@@ -676,6 +630,7 @@ int tipc_nametbl_mc_translate(u32 type, u32 lower, u32 upper, u32 limit,
struct name_seq *seq; struct name_seq *seq;
struct sub_seq *sseq; struct sub_seq *sseq;
struct sub_seq *sseq_stop; struct sub_seq *sseq_stop;
struct name_info *info;
int res = 0; int res = 0;
read_lock_bh(&tipc_nametbl_lock); read_lock_bh(&tipc_nametbl_lock);
...@@ -693,16 +648,13 @@ int tipc_nametbl_mc_translate(u32 type, u32 lower, u32 upper, u32 limit, ...@@ -693,16 +648,13 @@ int tipc_nametbl_mc_translate(u32 type, u32 lower, u32 upper, u32 limit,
if (sseq->lower > upper) if (sseq->lower > upper)
break; break;
publ = sseq->node_list; info = sseq->info;
if (publ) { list_for_each_entry(publ, &info->node_list, node_list) {
do {
if (publ->scope <= limit) if (publ->scope <= limit)
tipc_port_list_add(dports, publ->ref); tipc_port_list_add(dports, publ->ref);
publ = publ->node_list_next;
} while (publ != sseq->node_list);
} }
if (sseq->cluster_list_size != sseq->node_list_size) if (info->cluster_list_size != info->node_list_size)
res = 1; res = 1;
} }
...@@ -840,16 +792,19 @@ static void subseq_list(struct sub_seq *sseq, struct print_buf *buf, u32 depth, ...@@ -840,16 +792,19 @@ static void subseq_list(struct sub_seq *sseq, struct print_buf *buf, u32 depth,
{ {
char portIdStr[27]; char portIdStr[27];
const char *scope_str[] = {"", " zone", " cluster", " node"}; const char *scope_str[] = {"", " zone", " cluster", " node"};
struct publication *publ = sseq->zone_list; struct publication *publ;
struct name_info *info;
tipc_printf(buf, "%-10u %-10u ", sseq->lower, sseq->upper); tipc_printf(buf, "%-10u %-10u ", sseq->lower, sseq->upper);
if (depth == 2 || !publ) { if (depth == 2) {
tipc_printf(buf, "\n"); tipc_printf(buf, "\n");
return; return;
} }
do { info = sseq->info;
list_for_each_entry(publ, &info->zone_list, zone_list) {
sprintf(portIdStr, "<%u.%u.%u:%u>", sprintf(portIdStr, "<%u.%u.%u:%u>",
tipc_zone(publ->node), tipc_cluster(publ->node), tipc_zone(publ->node), tipc_cluster(publ->node),
tipc_node(publ->node), publ->ref); tipc_node(publ->node), publ->ref);
...@@ -858,13 +813,9 @@ static void subseq_list(struct sub_seq *sseq, struct print_buf *buf, u32 depth, ...@@ -858,13 +813,9 @@ static void subseq_list(struct sub_seq *sseq, struct print_buf *buf, u32 depth,
tipc_printf(buf, "%-10u %s", publ->key, tipc_printf(buf, "%-10u %s", publ->key,
scope_str[publ->scope]); scope_str[publ->scope]);
} }
if (!list_is_last(&publ->zone_list, &info->zone_list))
publ = publ->zone_list_next;
if (publ == sseq->zone_list)
break;
tipc_printf(buf, "\n%33s", " "); tipc_printf(buf, "\n%33s", " ");
} while (1); };
tipc_printf(buf, "\n"); tipc_printf(buf, "\n");
} }
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* net/tipc/name_table.h: Include file for TIPC name table code * net/tipc/name_table.h: Include file for TIPC name table code
* *
* Copyright (c) 2000-2006, Ericsson AB * Copyright (c) 2000-2006, Ericsson AB
* Copyright (c) 2004-2005, Wind River Systems * Copyright (c) 2004-2005, 2010-2011, Wind River Systems
* All rights reserved. * All rights reserved.
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
...@@ -61,9 +61,9 @@ struct port_list; ...@@ -61,9 +61,9 @@ struct port_list;
* @subscr: subscription to "node down" event (for off-node publications only) * @subscr: subscription to "node down" event (for off-node publications only)
* @local_list: adjacent entries in list of publications made by this node * @local_list: adjacent entries in list of publications made by this node
* @pport_list: adjacent entries in list of publications made by this port * @pport_list: adjacent entries in list of publications made by this port
* @node_list: next matching name seq publication with >= node scope * @node_list: adjacent matching name seq publications with >= node scope
* @cluster_list: next matching name seq publication with >= cluster scope * @cluster_list: adjacent matching name seq publications with >= cluster scope
* @zone_list: next matching name seq publication with >= zone scope * @zone_list: adjacent matching name seq publications with >= zone scope
* *
* Note that the node list, cluster list, and zone list are circular lists. * Note that the node list, cluster list, and zone list are circular lists.
*/ */
...@@ -79,9 +79,9 @@ struct publication { ...@@ -79,9 +79,9 @@ struct publication {
struct tipc_node_subscr subscr; struct tipc_node_subscr subscr;
struct list_head local_list; struct list_head local_list;
struct list_head pport_list; struct list_head pport_list;
struct publication *node_list_next; struct list_head node_list;
struct publication *cluster_list_next; struct list_head cluster_list;
struct publication *zone_list_next; struct list_head zone_list;
}; };
......
...@@ -222,7 +222,7 @@ struct tipc_port *tipc_createport_raw(void *usr_handle, ...@@ -222,7 +222,7 @@ struct tipc_port *tipc_createport_raw(void *usr_handle,
p_ptr->max_pkt = MAX_PKT_DEFAULT; p_ptr->max_pkt = MAX_PKT_DEFAULT;
p_ptr->ref = ref; p_ptr->ref = ref;
msg = &p_ptr->phdr; msg = &p_ptr->phdr;
tipc_msg_init(msg, importance, TIPC_NAMED_MSG, LONG_H_SIZE, 0); tipc_msg_init(msg, importance, TIPC_NAMED_MSG, NAMED_H_SIZE, 0);
msg_set_origport(msg, ref); msg_set_origport(msg, ref);
INIT_LIST_HEAD(&p_ptr->wait_list); INIT_LIST_HEAD(&p_ptr->wait_list);
INIT_LIST_HEAD(&p_ptr->subscription.nodesub_list); INIT_LIST_HEAD(&p_ptr->subscription.nodesub_list);
...@@ -327,26 +327,23 @@ int tipc_set_portunreturnable(u32 ref, unsigned int isunrejectable) ...@@ -327,26 +327,23 @@ int tipc_set_portunreturnable(u32 ref, unsigned int isunrejectable)
} }
/* /*
* port_build_proto_msg(): build a port level protocol * port_build_proto_msg(): create connection protocol message for port
* or a connection abortion message. Called with *
* tipc_port lock on. * On entry the port must be locked and connected.
*/ */
static struct sk_buff *port_build_proto_msg(u32 destport, u32 destnode, static struct sk_buff *port_build_proto_msg(struct tipc_port *p_ptr,
u32 origport, u32 orignode, u32 type, u32 ack)
u32 usr, u32 type, u32 err,
u32 ack)
{ {
struct sk_buff *buf; struct sk_buff *buf;
struct tipc_msg *msg; struct tipc_msg *msg;
buf = tipc_buf_acquire(LONG_H_SIZE); buf = tipc_buf_acquire(INT_H_SIZE);
if (buf) { if (buf) {
msg = buf_msg(buf); msg = buf_msg(buf);
tipc_msg_init(msg, usr, type, LONG_H_SIZE, destnode); tipc_msg_init(msg, CONN_MANAGER, type, INT_H_SIZE,
msg_set_errcode(msg, err); port_peernode(p_ptr));
msg_set_destport(msg, destport); msg_set_destport(msg, port_peerport(p_ptr));
msg_set_origport(msg, origport); msg_set_origport(msg, p_ptr->ref);
msg_set_orignode(msg, orignode);
msg_set_msgcnt(msg, ack); msg_set_msgcnt(msg, ack);
} }
return buf; return buf;
...@@ -358,45 +355,48 @@ int tipc_reject_msg(struct sk_buff *buf, u32 err) ...@@ -358,45 +355,48 @@ int tipc_reject_msg(struct sk_buff *buf, u32 err)
struct sk_buff *rbuf; struct sk_buff *rbuf;
struct tipc_msg *rmsg; struct tipc_msg *rmsg;
int hdr_sz; int hdr_sz;
u32 imp = msg_importance(msg); u32 imp;
u32 data_sz = msg_data_sz(msg); u32 data_sz = msg_data_sz(msg);
u32 src_node;
if (data_sz > MAX_REJECT_SIZE) u32 rmsg_sz;
data_sz = MAX_REJECT_SIZE;
if (msg_connected(msg) && (imp < TIPC_CRITICAL_IMPORTANCE))
imp++;
/* discard rejected message if it shouldn't be returned to sender */ /* discard rejected message if it shouldn't be returned to sender */
if (msg_errcode(msg) || msg_dest_droppable(msg)) {
buf_discard(buf);
return data_sz;
}
/* construct rejected message */ if (WARN(!msg_isdata(msg),
if (msg_mcast(msg)) "attempt to reject message with user=%u", msg_user(msg))) {
hdr_sz = MCAST_H_SIZE; dump_stack();
else goto exit;
hdr_sz = LONG_H_SIZE;
rbuf = tipc_buf_acquire(data_sz + hdr_sz);
if (rbuf == NULL) {
buf_discard(buf);
return data_sz;
} }
if (msg_errcode(msg) || msg_dest_droppable(msg))
goto exit;
/*
* construct returned message by copying rejected message header and
* data (or subset), then updating header fields that need adjusting
*/
hdr_sz = msg_hdr_sz(msg);
rmsg_sz = hdr_sz + min_t(u32, data_sz, MAX_REJECT_SIZE);
rbuf = tipc_buf_acquire(rmsg_sz);
if (rbuf == NULL)
goto exit;
rmsg = buf_msg(rbuf); rmsg = buf_msg(rbuf);
tipc_msg_init(rmsg, imp, msg_type(msg), hdr_sz, msg_orignode(msg)); skb_copy_to_linear_data(rbuf, msg, rmsg_sz);
msg_set_errcode(rmsg, err);
msg_set_destport(rmsg, msg_origport(msg)); if (msg_connected(rmsg)) {
msg_set_origport(rmsg, msg_destport(msg)); imp = msg_importance(rmsg);
if (msg_short(msg)) { if (imp < TIPC_CRITICAL_IMPORTANCE)
msg_set_orignode(rmsg, tipc_own_addr); msg_set_importance(rmsg, ++imp);
/* leave name type & instance as zeroes */
} else {
msg_set_orignode(rmsg, msg_destnode(msg));
msg_set_nametype(rmsg, msg_nametype(msg));
msg_set_nameinst(rmsg, msg_nameinst(msg));
} }
msg_set_size(rmsg, data_sz + hdr_sz); msg_set_non_seq(rmsg, 0);
skb_copy_to_linear_data_offset(rbuf, hdr_sz, msg_data(msg), data_sz); msg_set_size(rmsg, rmsg_sz);
msg_set_errcode(rmsg, err);
msg_set_prevnode(rmsg, tipc_own_addr);
msg_swap_words(rmsg, 4, 5);
if (!msg_short(rmsg))
msg_swap_words(rmsg, 6, 7);
/* send self-abort message when rejecting on a connected port */ /* send self-abort message when rejecting on a connected port */
if (msg_connected(msg)) { if (msg_connected(msg)) {
...@@ -411,9 +411,15 @@ int tipc_reject_msg(struct sk_buff *buf, u32 err) ...@@ -411,9 +411,15 @@ int tipc_reject_msg(struct sk_buff *buf, u32 err)
tipc_net_route_msg(abuf); tipc_net_route_msg(abuf);
} }
/* send rejected message */ /* send returned message & dispose of rejected message */
src_node = msg_prevnode(msg);
if (src_node == tipc_own_addr)
tipc_port_recv_msg(rbuf);
else
tipc_link_send(rbuf, src_node, msg_link_selector(rmsg));
exit:
buf_discard(buf); buf_discard(buf);
tipc_net_route_msg(rbuf);
return data_sz; return data_sz;
} }
...@@ -449,14 +455,7 @@ static void port_timeout(unsigned long ref) ...@@ -449,14 +455,7 @@ static void port_timeout(unsigned long ref)
if (p_ptr->probing_state == PROBING) { if (p_ptr->probing_state == PROBING) {
buf = port_build_self_abort_msg(p_ptr, TIPC_ERR_NO_PORT); buf = port_build_self_abort_msg(p_ptr, TIPC_ERR_NO_PORT);
} else { } else {
buf = port_build_proto_msg(port_peerport(p_ptr), buf = port_build_proto_msg(p_ptr, CONN_PROBE, 0);
port_peernode(p_ptr),
p_ptr->ref,
tipc_own_addr,
CONN_MANAGER,
CONN_PROBE,
TIPC_OK,
0);
p_ptr->probing_state = PROBING; p_ptr->probing_state = PROBING;
k_start_timer(&p_ptr->timer, p_ptr->probing_interval); k_start_timer(&p_ptr->timer, p_ptr->probing_interval);
} }
...@@ -480,100 +479,94 @@ static void port_handle_node_down(unsigned long ref) ...@@ -480,100 +479,94 @@ static void port_handle_node_down(unsigned long ref)
static struct sk_buff *port_build_self_abort_msg(struct tipc_port *p_ptr, u32 err) static struct sk_buff *port_build_self_abort_msg(struct tipc_port *p_ptr, u32 err)
{ {
u32 imp = msg_importance(&p_ptr->phdr); struct sk_buff *buf = port_build_peer_abort_msg(p_ptr, err);
if (!p_ptr->connected) if (buf) {
return NULL; struct tipc_msg *msg = buf_msg(buf);
if (imp < TIPC_CRITICAL_IMPORTANCE) msg_swap_words(msg, 4, 5);
imp++; msg_swap_words(msg, 6, 7);
return port_build_proto_msg(p_ptr->ref, }
tipc_own_addr, return buf;
port_peerport(p_ptr),
port_peernode(p_ptr),
imp,
TIPC_CONN_MSG,
err,
0);
} }
static struct sk_buff *port_build_peer_abort_msg(struct tipc_port *p_ptr, u32 err) static struct sk_buff *port_build_peer_abort_msg(struct tipc_port *p_ptr, u32 err)
{ {
u32 imp = msg_importance(&p_ptr->phdr); struct sk_buff *buf;
struct tipc_msg *msg;
u32 imp;
if (!p_ptr->connected) if (!p_ptr->connected)
return NULL; return NULL;
buf = tipc_buf_acquire(BASIC_H_SIZE);
if (buf) {
msg = buf_msg(buf);
memcpy(msg, &p_ptr->phdr, BASIC_H_SIZE);
msg_set_hdr_sz(msg, BASIC_H_SIZE);
msg_set_size(msg, BASIC_H_SIZE);
imp = msg_importance(msg);
if (imp < TIPC_CRITICAL_IMPORTANCE) if (imp < TIPC_CRITICAL_IMPORTANCE)
imp++; msg_set_importance(msg, ++imp);
return port_build_proto_msg(port_peerport(p_ptr), msg_set_errcode(msg, err);
port_peernode(p_ptr), }
p_ptr->ref, return buf;
tipc_own_addr,
imp,
TIPC_CONN_MSG,
err,
0);
} }
void tipc_port_recv_proto_msg(struct sk_buff *buf) void tipc_port_recv_proto_msg(struct sk_buff *buf)
{ {
struct tipc_msg *msg = buf_msg(buf); struct tipc_msg *msg = buf_msg(buf);
struct tipc_port *p_ptr = tipc_port_lock(msg_destport(msg)); struct tipc_port *p_ptr;
u32 err = TIPC_OK;
struct sk_buff *r_buf = NULL; struct sk_buff *r_buf = NULL;
struct sk_buff *abort_buf = NULL; u32 orignode = msg_orignode(msg);
u32 origport = msg_origport(msg);
u32 destport = msg_destport(msg);
int wakeable;
/* Validate connection */
p_ptr = tipc_port_lock(destport);
if (!p_ptr || !p_ptr->connected ||
(port_peernode(p_ptr) != orignode) ||
(port_peerport(p_ptr) != origport)) {
r_buf = tipc_buf_acquire(BASIC_H_SIZE);
if (r_buf) {
msg = buf_msg(r_buf);
tipc_msg_init(msg, TIPC_HIGH_IMPORTANCE, TIPC_CONN_MSG,
BASIC_H_SIZE, orignode);
msg_set_errcode(msg, TIPC_ERR_NO_PORT);
msg_set_origport(msg, destport);
msg_set_destport(msg, origport);
}
if (p_ptr)
tipc_port_unlock(p_ptr);
goto exit;
}
if (!p_ptr) { /* Process protocol message sent by peer */
err = TIPC_ERR_NO_PORT;
} else if (p_ptr->connected) { switch (msg_type(msg)) {
if ((port_peernode(p_ptr) != msg_orignode(msg)) || case CONN_ACK:
(port_peerport(p_ptr) != msg_origport(msg))) { wakeable = tipc_port_congested(p_ptr) && p_ptr->congested &&
err = TIPC_ERR_NO_PORT;
} else if (msg_type(msg) == CONN_ACK) {
int wakeup = tipc_port_congested(p_ptr) &&
p_ptr->congested &&
p_ptr->wakeup; p_ptr->wakeup;
p_ptr->acked += msg_msgcnt(msg); p_ptr->acked += msg_msgcnt(msg);
if (tipc_port_congested(p_ptr)) if (!tipc_port_congested(p_ptr)) {
goto exit;
p_ptr->congested = 0; p_ptr->congested = 0;
if (!wakeup) if (wakeable)
goto exit;
p_ptr->wakeup(p_ptr); p_ptr->wakeup(p_ptr);
goto exit;
}
} else if (p_ptr->published) {
err = TIPC_ERR_NO_PORT;
} }
if (err) { break;
r_buf = port_build_proto_msg(msg_origport(msg), case CONN_PROBE:
msg_orignode(msg), r_buf = port_build_proto_msg(p_ptr, CONN_PROBE_REPLY, 0);
msg_destport(msg), break;
tipc_own_addr, default:
TIPC_HIGH_IMPORTANCE, /* CONN_PROBE_REPLY or unrecognized - no action required */
TIPC_CONN_MSG, break;
err,
0);
goto exit;
}
/* All is fine */
if (msg_type(msg) == CONN_PROBE) {
r_buf = port_build_proto_msg(msg_origport(msg),
msg_orignode(msg),
msg_destport(msg),
tipc_own_addr,
CONN_MANAGER,
CONN_PROBE_REPLY,
TIPC_OK,
0);
} }
p_ptr->probing_state = CONFIRMED; p_ptr->probing_state = CONFIRMED;
exit:
if (p_ptr)
tipc_port_unlock(p_ptr); tipc_port_unlock(p_ptr);
exit:
tipc_net_route_msg(r_buf); tipc_net_route_msg(r_buf);
tipc_net_route_msg(abort_buf);
buf_discard(buf); buf_discard(buf);
} }
...@@ -889,14 +882,7 @@ void tipc_acknowledge(u32 ref, u32 ack) ...@@ -889,14 +882,7 @@ void tipc_acknowledge(u32 ref, u32 ack)
return; return;
if (p_ptr->connected) { if (p_ptr->connected) {
p_ptr->conn_unacked -= ack; p_ptr->conn_unacked -= ack;
buf = port_build_proto_msg(port_peerport(p_ptr), buf = port_build_proto_msg(p_ptr, CONN_ACK, ack);
port_peernode(p_ptr),
ref,
tipc_own_addr,
CONN_MANAGER,
CONN_ACK,
TIPC_OK,
ack);
} }
tipc_port_unlock(p_ptr); tipc_port_unlock(p_ptr);
tipc_net_route_msg(buf); tipc_net_route_msg(buf);
...@@ -1140,19 +1126,7 @@ int tipc_shutdown(u32 ref) ...@@ -1140,19 +1126,7 @@ int tipc_shutdown(u32 ref)
if (!p_ptr) if (!p_ptr)
return -EINVAL; return -EINVAL;
if (p_ptr->connected) { buf = port_build_peer_abort_msg(p_ptr, TIPC_CONN_SHUTDOWN);
u32 imp = msg_importance(&p_ptr->phdr);
if (imp < TIPC_CRITICAL_IMPORTANCE)
imp++;
buf = port_build_proto_msg(port_peerport(p_ptr),
port_peernode(p_ptr),
ref,
tipc_own_addr,
imp,
TIPC_CONN_MSG,
TIPC_CONN_SHUTDOWN,
0);
}
tipc_port_unlock(p_ptr); tipc_port_unlock(p_ptr);
tipc_net_route_msg(buf); tipc_net_route_msg(buf);
return tipc_disconnect(ref); return tipc_disconnect(ref);
...@@ -1238,7 +1212,7 @@ int tipc_send2name(u32 ref, struct tipc_name const *name, unsigned int domain, ...@@ -1238,7 +1212,7 @@ int tipc_send2name(u32 ref, struct tipc_name const *name, unsigned int domain,
msg_set_type(msg, TIPC_NAMED_MSG); msg_set_type(msg, TIPC_NAMED_MSG);
msg_set_orignode(msg, tipc_own_addr); msg_set_orignode(msg, tipc_own_addr);
msg_set_origport(msg, ref); msg_set_origport(msg, ref);
msg_set_hdr_sz(msg, LONG_H_SIZE); msg_set_hdr_sz(msg, NAMED_H_SIZE);
msg_set_nametype(msg, name->type); msg_set_nametype(msg, name->type);
msg_set_nameinst(msg, name->instance); msg_set_nameinst(msg, name->instance);
msg_set_lookup_scope(msg, tipc_addr_scope(domain)); msg_set_lookup_scope(msg, tipc_addr_scope(domain));
...@@ -1291,7 +1265,7 @@ int tipc_send2port(u32 ref, struct tipc_portid const *dest, ...@@ -1291,7 +1265,7 @@ int tipc_send2port(u32 ref, struct tipc_portid const *dest,
msg_set_origport(msg, ref); msg_set_origport(msg, ref);
msg_set_destnode(msg, dest->node); msg_set_destnode(msg, dest->node);
msg_set_destport(msg, dest->ref); msg_set_destport(msg, dest->ref);
msg_set_hdr_sz(msg, DIR_MSG_H_SIZE); msg_set_hdr_sz(msg, BASIC_H_SIZE);
if (dest->node == tipc_own_addr) if (dest->node == tipc_own_addr)
res = tipc_port_recv_sections(p_ptr, num_sect, msg_sect, res = tipc_port_recv_sections(p_ptr, num_sect, msg_sect,
...@@ -1331,13 +1305,13 @@ int tipc_send_buf2port(u32 ref, struct tipc_portid const *dest, ...@@ -1331,13 +1305,13 @@ int tipc_send_buf2port(u32 ref, struct tipc_portid const *dest,
msg_set_origport(msg, ref); msg_set_origport(msg, ref);
msg_set_destnode(msg, dest->node); msg_set_destnode(msg, dest->node);
msg_set_destport(msg, dest->ref); msg_set_destport(msg, dest->ref);
msg_set_hdr_sz(msg, DIR_MSG_H_SIZE); msg_set_hdr_sz(msg, BASIC_H_SIZE);
msg_set_size(msg, DIR_MSG_H_SIZE + dsz); msg_set_size(msg, BASIC_H_SIZE + dsz);
if (skb_cow(buf, DIR_MSG_H_SIZE)) if (skb_cow(buf, BASIC_H_SIZE))
return -ENOMEM; return -ENOMEM;
skb_push(buf, DIR_MSG_H_SIZE); skb_push(buf, BASIC_H_SIZE);
skb_copy_to_linear_data(buf, msg, DIR_MSG_H_SIZE); skb_copy_to_linear_data(buf, msg, BASIC_H_SIZE);
if (dest->node == tipc_own_addr) if (dest->node == tipc_own_addr)
res = tipc_port_recv_msg(buf); res = tipc_port_recv_msg(buf);
......
...@@ -36,9 +36,6 @@ ...@@ -36,9 +36,6 @@
#include <net/sock.h> #include <net/sock.h>
#include <linux/tipc.h>
#include <linux/tipc_config.h>
#include "core.h" #include "core.h"
#include "port.h" #include "port.h"
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment