/* * wm8962.h -- WM8962 Soc Audio driver platform data * * 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. */ #ifndef _WM8962_PDATA_H #define _WM8962_PDATA_H #define WM8962_MAX_GPIO 6 /* Use to set GPIO default values to zero */ #define WM8962_GPIO_SET 0x10000 #define WM8962_GPIO_FN_CLKOUT 0 #define WM8962_GPIO_FN_LOGIC 1 #define WM8962_GPIO_FN_SDOUT 2 #define WM8962_GPIO_FN_IRQ 3 #define WM8962_GPIO_FN_THERMAL 4 #define WM8962_GPIO_FN_PLL2_LOCK 6 #define WM8962_GPIO_FN_PLL3_LOCK 7 #define WM8962_GPIO_FN_FLL_LOCK 9 #define WM8962_GPIO_FN_DRC_ACT 10 #define WM8962_GPIO_FN_WSEQ_DONE 11 #define WM8962_GPIO_FN_ALC_NG_ACT 12 #define WM8962_GPIO_FN_ALC_PEAK_LIMIT 13 #define WM8962_GPIO_FN_ALC_SATURATION 14 #define WM8962_GPIO_FN_ALC_LEVEL_THR 15 #define WM8962_GPIO_FN_ALC_LEVEL_LOCK 16 #define WM8962_GPIO_FN_FIFO_ERR 17 #define WM8962_GPIO_FN_OPCLK 18 #define WM8962_GPIO_FN_DMICCLK 19 #define WM8962_GPIO_FN_DMICDAT 20 #define WM8962_GPIO_FN_MICD 21 #define WM8962_GPIO_FN_MICSCD 22 struct wm8962_pdata { struct clk *mclk; int gpio_base; u32 gpio_init[WM8962_MAX_GPIO]; /* Setup for microphone detection, raw value to be written to * R48(0x30) - only microphone related bits will be updated. * Detection may be enabled here for use with signals brought * out on the GPIOs. */ u32 mic_cfg; bool irq_active_low; bool spk_mono; /* Speaker outputs tied together as mono */ /** * This flag should be set if one or both IN4 inputs is wired * in a DC measurement configuration. */ bool in4_dc_measure; }; #endif ff5bc3b9b25'>treecommitdiff
path: root/net/rose/af_rose.c
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2017-01-31 09:37:34 +0100
committerThomas Gleixner <tglx@linutronix.de>2017-01-31 21:47:58 +0100
commit0becc0ae5b42828785b589f686725ff5bc3b9b25 (patch)
treebe6d0e1f37c38ed0a7dd5da2d4b1e93f0fb43101 /net/rose/af_rose.c
parent24c2503255d35c269b67162c397a1a1c1e02f6ce (diff)
x86/mce: Make timer handling more robust
Erik reported that on a preproduction hardware a CMCI storm triggers the BUG_ON in add_timer_on(). The reason is that the per CPU MCE timer is started by the CMCI logic before the MCE CPU hotplug callback starts the timer with add_timer_on(). So the timer is already queued which triggers the BUG. Using add_timer_on() is pretty pointless in this code because the timer is strictlty per CPU, initialized as pinned and all operations which arm the timer happen on the CPU to which the timer belongs. Simplify the whole machinery by using mod_timer() instead of add_timer_on() which avoids the problem because mod_timer() can handle already queued timers. Use __start_timer() everywhere so the earliest armed expiry time is preserved. Reported-by: Erik Veijola <erik.veijola@intel.com> Tested-by: Borislav Petkov <bp@alien8.de> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Borislav Petkov <bp@alien8.de> Cc: Tony Luck <tony.luck@intel.com> Link: http://lkml.kernel.org/r/alpine.DEB.2.20.1701310936080.3457@nanos Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'net/rose/af_rose.c')