1 /* 2 * net/tipc/subscr.h: Include file for TIPC network topology service 3 * 4 * Copyright (c) 2003-2017, Ericsson AB 5 * Copyright (c) 2005-2007, 2012-2013, Wind River Systems 6 * Copyright (c) 2020-2021, Red Hat Inc 7 * All rights reserved. 8 * 9 * Redistribution and use in source and binary forms, with or without 10 * modification, are permitted provided that the following conditions are met: 11 * 12 * 1. Redistributions of source code must retain the above copyright 13 * notice, this list of conditions and the following disclaimer. 14 * 2. Redistributions in binary form must reproduce the above copyright 15 * notice, this list of conditions and the following disclaimer in the 16 * documentation and/or other materials provided with the distribution. 17 * 3. Neither the names of the copyright holders nor the names of its 18 * contributors may be used to endorse or promote products derived from 19 * this software without specific prior written permission. 20 * 21 * Alternatively, this software may be distributed under the terms of the 22 * GNU General Public License ("GPL") version 2 as published by the Free 23 * Software Foundation. 24 * 25 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 26 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 28 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 29 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 30 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 31 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 33 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 34 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 35 * POSSIBILITY OF SUCH DAMAGE. 36 */ 37 38 #ifndef _TIPC_SUBSCR_H 39 #define _TIPC_SUBSCR_H 40 41 #include "topsrv.h" 42 43 #define TIPC_MAX_SUBSCR 65535 44 #define TIPC_MAX_PUBL 65535 45 46 struct publication; 47 struct tipc_subscription; 48 struct tipc_conn; 49 50 /** 51 * struct tipc_subscription - TIPC network topology subscription object 52 * @kref: reference count for this subscription 53 * @net: network namespace associated with subscription 54 * @timer: timer governing subscription duration (optional) 55 * @service_list: adjacent subscriptions in name sequence's subscription list 56 * @sub_list: adjacent subscriptions in subscriber's subscription list 57 * @evt: template for events generated by subscription 58 * @conid: connection identifier of topology server 59 * @inactive: true if this subscription is inactive 60 * @lock: serialize up/down and timer events 61 */ 62 struct tipc_subscription { 63 struct tipc_subscr s; 64 struct tipc_event evt; 65 struct kref kref; 66 struct net *net; 67 struct timer_list timer; 68 struct list_head service_list; 69 struct list_head sub_list; 70 int conid; 71 bool inactive; 72 spinlock_t lock; 73 }; 74 75 struct tipc_subscription *tipc_sub_subscribe(struct net *net, 76 struct tipc_subscr *s, 77 int conid); 78 void tipc_sub_unsubscribe(struct tipc_subscription *sub); 79 void tipc_sub_report_overlap(struct tipc_subscription *sub, 80 struct publication *p, 81 u32 event, bool must); 82 83 int __net_init tipc_topsrv_init_net(struct net *net); 84 void __net_exit tipc_topsrv_exit_net(struct net *net); 85 86 void tipc_sub_put(struct tipc_subscription *subscription); 87 void tipc_sub_get(struct tipc_subscription *subscription); 88 89 #define TIPC_FILTER_MASK (TIPC_SUB_PORTS | TIPC_SUB_SERVICE | TIPC_SUB_CANCEL) 90 91 /* tipc_sub_read - return field_ of struct sub_ in host endian format 92 */ 93 #define tipc_sub_read(sub_, field_) \ 94 ({ \ 95 struct tipc_subscr *sub__ = sub_; \ 96 u32 val__ = (sub__)->field_; \ 97 int swap_ = !((sub__)->filter & TIPC_FILTER_MASK); \ 98 (swap_ ? swab32(val__) : val__); \ 99 }) 100 101 /* tipc_sub_write - write val_ to field_ of struct sub_ in user endian format 102 */ 103 #define tipc_sub_write(sub_, field_, val_) \ 104 ({ \ 105 struct tipc_subscr *sub__ = sub_; \ 106 u32 val__ = val_; \ 107 int swap_ = !((sub__)->filter & TIPC_FILTER_MASK); \ 108 (sub__)->field_ = swap_ ? swab32(val__) : val__; \ 109 }) 110 111 /* tipc_evt_write - write val_ to field_ of struct evt_ in user endian format 112 */ 113 #define tipc_evt_write(evt_, field_, val_) \ 114 ({ \ 115 struct tipc_event *evt__ = evt_; \ 116 u32 val__ = val_; \ 117 int swap_ = !((evt__)->s.filter & (TIPC_FILTER_MASK)); \ 118 (evt__)->field_ = swap_ ? swab32(val__) : val__; \ 119 }) 120 121 #endif 122