Skip to content
Snippets Groups Projects
Select Git revision
  • 248d58d79f26829d70fe18f6aede48bc807e0afe
  • master default protected
  • r1.8
  • r1.6
  • r1.9
  • r1.5
  • r1.7
  • r1.3
  • r1.4
  • r1.2
  • v1.6.0
  • v1.5.0
12 results

infer_psenet_onnx.py

Blame
  • node.c 17.87 KiB
    /*
     * net/tipc/node.c: TIPC node management routines
     *
     * Copyright (c) 2000-2006, 2012-2014, Ericsson AB
     * Copyright (c) 2005-2006, 2010-2014, Wind River Systems
     * All rights reserved.
     *
     * Redistribution and use in source and binary forms, with or without
     * modification, are permitted provided that the following conditions are met:
     *
     * 1. Redistributions of source code must retain the above copyright
     *    notice, this list of conditions and the following disclaimer.
     * 2. Redistributions in binary form must reproduce the above copyright
     *    notice, this list of conditions and the following disclaimer in the
     *    documentation and/or other materials provided with the distribution.
     * 3. Neither the names of the copyright holders nor the names of its
     *    contributors may be used to endorse or promote products derived from
     *    this software without specific prior written permission.
     *
     * Alternatively, this software may be distributed under the terms of the
     * GNU General Public License ("GPL") version 2 as published by the Free
     * Software Foundation.
     *
     * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
     * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
     * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     * POSSIBILITY OF SUCH DAMAGE.
     */
    
    #include "core.h"
    #include "config.h"
    #include "node.h"
    #include "name_distr.h"
    #include "socket.h"
    
    #define NODE_HTABLE_SIZE 512
    
    static void node_lost_contact(struct tipc_node *n_ptr);
    static void node_established_contact(struct tipc_node *n_ptr);
    
    static struct hlist_head node_htable[NODE_HTABLE_SIZE];
    LIST_HEAD(tipc_node_list);
    static u32 tipc_num_nodes;
    static u32 tipc_num_links;
    static DEFINE_SPINLOCK(node_list_lock);
    
    struct tipc_sock_conn {
    	u32 port;
    	u32 peer_port;
    	u32 peer_node;
    	struct list_head list;
    };
    
    static const struct nla_policy tipc_nl_node_policy[TIPC_NLA_NODE_MAX + 1] = {
    	[TIPC_NLA_NODE_UNSPEC]		= { .type = NLA_UNSPEC },
    	[TIPC_NLA_NODE_ADDR]		= { .type = NLA_U32 },
    	[TIPC_NLA_NODE_UP]		= { .type = NLA_FLAG }
    };
    
    /*
     * A trivial power-of-two bitmask technique is used for speed, since this
     * operation is done for every incoming TIPC packet. The number of hash table
     * entries has been chosen so that no hash chain exceeds 8 nodes and will