/* * nop (passthrough) Link Layer Control * * Copyright (C) 2012 Intel Corporation. All rights reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions 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, see . */ #include #include "llc.h" struct llc_nop { struct nfc_hci_dev *hdev; xmit_to_drv_t xmit_to_drv; rcv_to_hci_t rcv_to_hci; int tx_headroom; int tx_tailroom; llc_failure_t llc_failure; }; static void *llc_nop_init(struct nfc_hci_dev *hdev, xmit_to_drv_t xmit_to_drv, rcv_to_hci_t rcv_to_hci, int tx_headroom, int tx_tailroom, int *rx_headroom, int *rx_tailroom, llc_failure_t llc_failure) { struct llc_nop *llc_nop; *rx_headroom = 0; *rx_tailroom = 0; llc_nop = kzalloc(sizeof(struct llc_nop), GFP_KERNEL); if (llc_nop == NULL) return NULL; llc_nop->hdev = hdev; llc_nop->xmit_to_drv = xmit_to_drv; llc_nop->rcv_to_hci = rcv_to_hci; llc_nop->tx_headroom = tx_headroom; llc_nop->tx_tailroom = tx_tailroom; llc_nop->llc_failure = llc_failure; return llc_nop; } static void llc_nop_deinit(struct nfc_llc *llc) { kfree(nfc_llc_get_data(llc)); } static int llc_nop_start(struct nfc_llc *llc) { return 0; } static int llc_nop_stop(struct nfc_llc *llc) { return 0; } static void llc_nop_rcv_from_drv(struct nfc_llc *llc, struct sk_buff *skb) { struct llc_nop *llc_nop = nfc_llc_get_data(llc); llc_nop->rcv_to_hci(llc_nop->hdev, skb); } static int llc_nop_xmit_from_hci(struct nfc_llc *llc, struct sk_buff *skb) { struct llc_nop *llc_nop = nfc_llc_get_data(llc); return llc_nop->xmit_to_drv(llc_nop->hdev, skb); } static struct nfc_llc_ops llc_nop_ops = { .init = llc_nop_init, .deinit = llc_nop_deinit, .start = llc_nop_start, .stop = llc_nop_stop, .rcv_from_drv = llc_nop_rcv_from_drv, .xmit_from_hci = llc_nop_xmit_from_hci, }; int nfc_llc_nop_register(void) { return nfc_llc_register(LLC_NOP_NAME, &llc_nop_ops); } ption>
diff options
context:
space:
mode:
authorJiri Slaby <jslaby@suse.cz>2016-12-19 16:23:12 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2016-12-20 09:48:47 -0800
commit1b011e2f13fcf37e1e577fed25b295808d6c83b9 (patch)
tree50bb2b58757f3c578f40dec19c2b42a8d6bc534d /include/uapi/sound
parent4983f0ab7ffaad1e534b21975367429736475205 (diff)
ratelimit: fix WARN_ON_RATELIMIT return value
The macro is to be used similarly as WARN_ON as: if (WARN_ON_RATELIMIT(condition, state)) do_something(); One would expect only 'condition' to affect the 'if', but WARN_ON_RATELIMIT does internally only: WARN_ON((condition) && __ratelimit(state)) So the 'if' is affected by the ratelimiting state too. Fix this by returning 'condition' in any case. Note that nobody uses WARN_ON_RATELIMIT yet, so there is nothing to worry about. But I was about to use it and was a bit surprised. Link: http://lkml.kernel.org/r/20161215093224.23126-1-jslaby@suse.cz Signed-off-by: Jiri Slaby <jslaby@suse.cz> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'include/uapi/sound')