/* * Linux WiMAX * Internal API for kernel space WiMAX stack * * * Copyright (C) 2007 Intel Corporation * Inaky Perez-Gonzalez * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License version * 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301, USA. * * * This header file is for declarations and definitions internal to * the WiMAX stack. For public APIs and documentation, see * include/net/wimax.h and include/linux/wimax.h. */ #ifndef __WIMAX_INTERNAL_H__ #define __WIMAX_INTERNAL_H__ #ifdef __KERNEL__ #ifdef pr_fmt #undef pr_fmt #endif #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt #include #include /* * Decide if a (locked) device is ready for use * * Before using the device structure, it must be locked * (wimax_dev->mutex). As well, most operations need to call this * function to check if the state is the right one. * * An error value will be returned if the state is not the right * one. In that case, the caller should not attempt to use the device * and just unlock it. */ static inline __must_check int wimax_dev_is_ready(struct wimax_dev *wimax_dev) { if (wimax_dev->state == __WIMAX_ST_NULL) return -EINVAL; /* Device is not even registered! */ if (wimax_dev->state == WIMAX_ST_DOWN) return -ENOMEDIUM; if (wimax_dev->state == __WIMAX_ST_QUIESCING) return -ESHUTDOWN; return 0; } static inline void __wimax_state_set(struct wimax_dev *wimax_dev, enum wimax_st state) { wimax_dev->state = state; } void __wimax_state_change(struct wimax_dev *, enum wimax_st); #ifdef CONFIG_DEBUG_FS int wimax_debugfs_add(struct wimax_dev *); void wimax_debugfs_rm(struct wimax_dev *); #else static inline int wimax_debugfs_add(struct wimax_dev *wimax_dev) { return 0; } static inline void wimax_debugfs_rm(struct wimax_dev *wimax_dev) {} #endif void wimax_id_table_add(struct wimax_dev *); struct wimax_dev *wimax_dev_get_by_genl_info(struct genl_info *, int); void wimax_id_table_rm(struct wimax_dev *); void wimax_id_table_release(void); int wimax_rfkill_add(struct wimax_dev *); void wimax_rfkill_rm(struct wimax_dev *); /* generic netlink */ extern struct genl_family wimax_gnl_family; /* ops */ int wimax_gnl_doit_msg_from_user(struct sk_buff *skb, struct genl_info *info); int wimax_gnl_doit_reset(struct sk_buff *skb, struct genl_info *info); int wimax_gnl_doit_rfkill(struct sk_buff *skb, struct genl_info *info); int wimax_gnl_doit_state_get(struct sk_buff *skb, struct genl_info *info); #endif /* #ifdef __KERNEL__ */ #endif /* #ifndef __WIMAX_INTERNAL_H__ */ emove&id=d56a5ca366e785f463b4782f65daac883612a2b2'>tools/include/asm/barrier.h
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2017-01-28 11:50:17 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2017-01-28 11:50:17 -0800
commitd56a5ca366e785f463b4782f65daac883612a2b2 (patch)
tree26ff9bf940fc911e81ab22717d9e6c3258c74bf8 /tools/include/asm/barrier.h
parentdd553962675ab5747e887f89aea1ece90e6a802e (diff)
parentee6625a948d2e47267ec8fd97307fdd67d0f8a5b (diff)
Merge tag 'nfs-for-4.10-4' of git://git.linux-nfs.org/projects/trondmy/linux-nfs
Pull NFS client bugfixes from Trond Myklebust: "Stable patches: - NFSv4.1: Fix a deadlock in layoutget - NFSv4 must not bump sequence ids on NFS4ERR_MOVED errors - NFSv4 Fix a regression with OPEN EXCLUSIVE4 mode - Fix a memory leak when removing the SUNRPC module Bugfixes: - Fix a reference leak in _pnfs_return_layout" * tag 'nfs-for-4.10-4' of git://git.linux-nfs.org/projects/trondmy/linux-nfs: pNFS: Fix a reference leak in _pnfs_return_layout nfs: Fix "Don't increment lock sequence ID after NFS4ERR_MOVED" SUNRPC: cleanup ida information when removing sunrpc module NFSv4.0: always send mode in SETATTR after EXCLUSIVE4 nfs: Don't increment lock sequence ID after NFS4ERR_MOVED NFSv4.1: Fix a deadlock in layoutget
Diffstat (limited to 'tools/include/asm/barrier.h')