/********************************************************************* * * Filename: af_irda.h * Version: 1.0 * Description: IrDA sockets declarations * Status: Stable * Author: Dag Brattli * Created at: Tue Dec 9 21:13:12 1997 * Modified at: Fri Jan 28 13:16:32 2000 * Modified by: Dag Brattli * * Copyright (c) 1998-2000 Dag Brattli, All Rights Reserved. * Copyright (c) 2000-2002 Jean Tourrilhes * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * Neither Dag Brattli nor University of Tromsø admit liability nor * provide warranty for any of this software. This material is * provided "AS-IS" and at no charge. * ********************************************************************/ #ifndef AF_IRDA_H #define AF_IRDA_H #include #include #include /* struct iriap_cb */ #include /* struct ias_value */ #include /* struct lsap_cb */ #include /* struct tsap_cb */ #include /* struct discovery_t */ #include /* IrDA Socket */ struct irda_sock { /* struct sock has to be the first member of irda_sock */ struct sock sk; __u32 saddr; /* my local address */ __u32 daddr; /* peer address */ struct lsap_cb *lsap; /* LSAP used by Ultra */ __u8 pid; /* Protocol IP (PID) used by Ultra */ struct tsap_cb *tsap; /* TSAP used by this connection */ __u8 dtsap_sel; /* remote TSAP address */ __u8 stsap_sel; /* local TSAP address */ __u32 max_sdu_size_rx; __u32 max_sdu_size_tx; __u32 max_data_size; __u8 max_header_size; struct qos_info qos_tx; __u16_host_order mask; /* Hint bits mask */ __u16_host_order hints; /* Hint bits */ void *ckey; /* IrLMP client handle */ void *skey; /* IrLMP service handle */ struct ias_object *ias_obj; /* Our service name + lsap in IAS */ struct iriap_cb *iriap; /* Used to query remote IAS */ struct ias_value *ias_result; /* Result of remote IAS query */ hashbin_t *cachelog; /* Result of discovery query */ __u32 cachedaddr; /* Result of selective discovery query */ int nslots; /* Number of slots to use for discovery */ int errno; /* status of the IAS query */ wait_queue_head_t query_wait; /* Wait for the answer to a query */ struct timer_list watchdog; /* Timeout for discovery */ LOCAL_FLOW tx_flow; LOCAL_FLOW rx_flow; }; static inline struct irda_sock *irda_sk(struct sock *sk) { return (struct irda_sock *)sk; } #endif /* AF_IRDA_H */ '>wireless/core.c
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2016-12-18 14:35:45 +0100
committerDaniel Vetter <daniel.vetter@ffwll.ch>2017-01-30 10:17:17 +0100
commit4e5b54f127426c82dc2816340c26d951a5bb3429 (patch)
treecc3a8f7e335cf12880bc8d1a1e2066f6cfe0a68e /net/wireless/core.c
parent566cf877a1fcb6d6dc0126b076aad062054c2637 (diff)
drm: prevent double-(un)registration for connectors
If we're unlucky then the registration from a hotplugged connector might race with the final registration step on driver load. And since MST topology discover is asynchronous that's even somewhat likely. v2: Also update the kerneldoc for @registered! v3: Review from Chris: - Improve kerneldoc for late_register/early_unregister callbacks. - Use mutex_destroy. Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Sean Paul <seanpaul@chromium.org> Reported-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Daniel Vetter <daniel.vetter@intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/20161218133545.2106-1-daniel.vetter@ffwll.ch (cherry picked from commit e73ab00e9a0f1731f34d0620a9c55f5c30c4ad4e)
Diffstat (limited to 'net/wireless/core.c')