/* * Copyright 2014 Linaro Ltd. * Copyright (C) 2014 ZTE Corporation. * * 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 __DT_BINDINGS_CLOCK_ZX296702_H #define __DT_BINDINGS_CLOCK_ZX296702_H #define ZX296702_OSC 0 #define ZX296702_PLL_A9 1 #define ZX296702_PLL_A9_350M 2 #define ZX296702_PLL_MAC_1000M 3 #define ZX296702_PLL_MAC_333M 4 #define ZX296702_PLL_MM0_1188M 5 #define ZX296702_PLL_MM0_396M 6 #define ZX296702_PLL_MM0_198M 7 #define ZX296702_PLL_MM1_108M 8 #define ZX296702_PLL_MM1_72M 9 #define ZX296702_PLL_MM1_54M 10 #define ZX296702_PLL_LSP_104M 11 #define ZX296702_PLL_LSP_26M 12 #define ZX296702_PLL_AUDIO_294M912 13 #define ZX296702_PLL_DDR_266M 14 #define ZX296702_CLK_148M5 15 #define ZX296702_MATRIX_ACLK 16 #define ZX296702_MAIN_HCLK 17 #define ZX296702_MAIN_PCLK 18 #define ZX296702_CLK_500 19 #define ZX296702_CLK_250 20 #define ZX296702_CLK_125 21 #define ZX296702_CLK_74M25 22 #define ZX296702_A9_WCLK 23 #define ZX296702_A9_AS1_ACLK_MUX 24 #define ZX296702_A9_TRACE_CLKIN_MUX 25 #define ZX296702_A9_AS1_ACLK_DIV 26 #define ZX296702_CLK_2 27 #define ZX296702_CLK_27 28 #define ZX296702_DECPPU_ACLK_MUX 29 #define ZX296702_PPU_ACLK_MUX 30 #define ZX296702_MALI400_ACLK_MUX 31 #define ZX296702_VOU_ACLK_MUX 32 #define ZX296702_VOU_MAIN_WCLK_MUX 33 #define ZX296702_VOU_AUX_WCLK_MUX 34 #define ZX296702_VOU_SCALER_WCLK_MUX 35 #define ZX296702_R2D_ACLK_MUX 36 #define ZX296702_R2D_WCLK_MUX 37 #define ZX296702_CLK_50 38 #define ZX296702_CLK_25 39 #define ZX296702_CLK_12 40 #define ZX296702_CLK_16M384 41 #define ZX296702_CLK_32K768 42 #define ZX296702_SEC_WCLK_DIV 43 #define ZX296702_DDR_WCLK_MUX 44 #define ZX296702_NAND_WCLK_MUX 45 #define ZX296702_LSP_26_WCLK_MUX 46 #define ZX296702_A9_AS0_ACLK 47 #define ZX296702_A9_AS1_ACLK 48 #define ZX296702_A9_TRACE_CLKIN 49 #define ZX296702_DECPPU_AXI_M_ACLK 50 #define ZX296702_DECPPU_AHB_S_HCLK 51 #define ZX296702_PPU_AXI_M_ACLK 52 #define ZX296702_PPU_AHB_S_HCLK 53 #define ZX296702_VOU_AXI_M_ACLK 54 #define ZX296702_VOU_APB_PCLK 55 #define ZX296702_VOU_MAIN_CHANNEL_WCLK 56 #define ZX296702_VOU_AUX_CHANNEL_WCLK 57 #define ZX296702_VOU_HDMI_OSCLK_CEC 58 #define ZX296702_VOU_SCALER_WCLK 59 #define ZX296702_MALI400_AXI_M_ACLK 60 #define ZX296702_MALI400_APB_PCLK 61 #define ZX296702_R2D_WCLK 62 #define ZX296702_R2D_AXI_M_ACLK 63 #define ZX296702_R2D_AHB_HCLK 64 #define ZX296702_DDR3_AXI_S0_ACLK 65 #define ZX296702_DDR3_APB_PCLK 66 #define ZX296702_DDR3_WCLK 67 #define ZX296702_USB20_0_AHB_HCLK 68 #define ZX296702_USB20_0_EXTREFCLK 69 #define ZX296702_USB20_1_AHB_HCLK 70 #define ZX296702_USB20_1_EXTREFCLK 71 #define ZX296702_USB20_2_AHB_HCLK 72 #define ZX296702_USB20_2_EXTREFCLK 73 #define ZX296702_GMAC_AXI_M_ACLK 74 #define ZX296702_GMAC_APB_PCLK 75 #define ZX296702_GMAC_125_CLKIN 76 #define ZX296702_GMAC_RMII_CLKIN 77 #define ZX296702_GMAC_25M_CLK 78 #define ZX296702_NANDFLASH_AHB_HCLK 79 #define ZX296702_NANDFLASH_WCLK 80 #define ZX296702_LSP0_APB_PCLK 81 #define ZX296702_LSP0_AHB_HCLK 82 #define ZX296702_LSP0_26M_WCLK 83 #define ZX296702_LSP0_104M_WCLK 84 #define ZX296702_LSP0_16M384_WCLK 85 #define ZX296702_LSP1_APB_PCLK 86 #define ZX296702_LSP1_26M_WCLK 87 #define ZX296702_LSP1_104M_WCLK 88 #define ZX296702_LSP1_32K_CLK 89 #define ZX296702_AON_HCLK 90 #define ZX296702_SYS_CTRL_PCLK 91 #define ZX296702_DMA_PCLK 92 #define ZX296702_DMA_ACLK 93 #define ZX296702_SEC_HCLK 94 #define ZX296702_AES_WCLK 95 #define ZX296702_DES_WCLK 96 #define ZX296702_IRAM_ACLK 97 #define ZX296702_IROM_ACLK 98 #define ZX296702_BOOT_CTRL_HCLK 99 #define ZX296702_EFUSE_CLK_30 100 #define ZX296702_VOU_MAIN_CHANNEL_DIV 101 #define ZX296702_VOU_AUX_CHANNEL_DIV 102 #define ZX296702_VOU_TV_ENC_HD_DIV 103 #define ZX296702_VOU_TV_ENC_SD_DIV 104 #define ZX296702_VL0_MUX 105 #define ZX296702_VL1_MUX 106 #define ZX296702_VL2_MUX 107 #define ZX296702_GL0_MUX 108 #define ZX296702_GL1_MUX 109 #define ZX296702_GL2_MUX 110 #define ZX296702_WB_MUX 111 #define ZX296702_HDMI_MUX 112 #define ZX296702_VOU_TV_ENC_HD_MUX 113 #define ZX296702_VOU_TV_ENC_SD_MUX 114 #define ZX296702_VL0_CLK 115 #define ZX296702_VL1_CLK 116 #define ZX296702_VL2_CLK 117 #define ZX296702_GL0_CLK 118 #define ZX296702_GL1_CLK 119 #define ZX296702_GL2_CLK 120 #define ZX296702_WB_CLK 121 #define ZX296702_CL_CLK 122 #define ZX296702_MAIN_MIX_CLK 123 #define ZX296702_AUX_MIX_CLK 124 #define ZX296702_HDMI_CLK 125 #define ZX296702_VOU_TV_ENC_HD_DAC_CLK 126 #define ZX296702_VOU_TV_ENC_SD_DAC_CLK 127 #define ZX296702_A9_PERIPHCLK 128 #define ZX296702_TOPCLK_END 129 #define ZX296702_SDMMC1_WCLK_MUX 0 #define ZX296702_SDMMC1_WCLK_DIV 1 #define ZX296702_SDMMC1_WCLK 2 #define ZX296702_SDMMC1_PCLK 3 #define ZX296702_SPDIF0_WCLK_MUX 4 #define ZX296702_SPDIF0_WCLK 5 #define ZX296702_SPDIF0_PCLK 6 #define ZX296702_SPDIF0_DIV 7 #define ZX296702_I2S0_WCLK_MUX 8 #define ZX296702_I2S0_WCLK 9 #define ZX296702_I2S0_PCLK 10 #define ZX296702_I2S0_DIV 11 #define ZX296702_I2S1_WCLK_MUX 12 #define ZX296702_I2S1_WCLK 13 #define ZX296702_I2S1_PCLK 14 #define ZX296702_I2S1_DIV 15 #define ZX296702_I2S2_WCLK_MUX 16 #define ZX296702_I2S2_WCLK 17 #define ZX296702_I2S2_PCLK 18 #define ZX296702_I2S2_DIV 19 #define ZX296702_GPIO_CLK 20 #define ZX296702_LSP0CLK_END 21 #define ZX296702_UART0_WCLK_MUX 0 #define ZX296702_UART0_WCLK 1 #define ZX296702_UART0_PCLK 2 #define ZX296702_UART1_WCLK_MUX 3 #define ZX296702_UART1_WCLK 4 #define ZX296702_UART1_PCLK 5 #define ZX296702_SDMMC0_WCLK_MUX 6 #define ZX296702_SDMMC0_WCLK_DIV 7 #define ZX296702_SDMMC0_WCLK 8 #define ZX296702_SDMMC0_PCLK 9 #define ZX296702_SPDIF1_WCLK_MUX 10 #define ZX296702_SPDIF1_WCLK 11 #define ZX296702_SPDIF1_PCLK 12 #define ZX296702_SPDIF1_DIV 13 #define ZX296702_LSP1CLK_END 14 #endif /* __DT_BINDINGS_CLOCK_ZX296702_H */ nce. But the return value from atomic_long_inc_not_zero() is a long and may have high bits set, e.g. PERCPU_COUNT_BIAS, and the return value of the tryget routines is bool so the reference may actually be acquired but the routines return "false" which results in a reference leak since the caller assumes it does not need to do a corresponding percpu_ref_put(). This was seen when performing CPU hotplug during I/O, as hangs in blk_mq_freeze_queue_wait where percpu_ref_kill (blk_mq_freeze_queue_start) raced with percpu_ref_tryget (blk_mq_timeout_work). Sample stack trace: __switch_to+0x2c0/0x450 __schedule+0x2f8/0x970 schedule+0x48/0xc0 blk_mq_freeze_queue_wait+0x94/0x120 blk_mq_queue_reinit_work+0xb8/0x180 blk_mq_queue_reinit_prepare+0x84/0xa0 cpuhp_invoke_callback+0x17c/0x600 cpuhp_up_callbacks+0x58/0x150 _cpu_up+0xf0/0x1c0 do_cpu_up+0x120/0x150 cpu_subsys_online+0x64/0xe0 device_online+0xb4/0x120 online_store+0xb4/0xc0 dev_attr_store+0x68/0xa0 sysfs_kf_write+0x80/0xb0 kernfs_fop_write+0x17c/0x250 __vfs_write+0x6c/0x1e0 vfs_write+0xd0/0x270 SyS_write+0x6c/0x110 system_call+0x38/0xe0 Examination of the queue showed a single reference (no PERCPU_COUNT_BIAS, and __PERCPU_REF_DEAD, __PERCPU_REF_ATOMIC set) and no requests. However, conditions at the time of the race are count of PERCPU_COUNT_BIAS + 0 and __PERCPU_REF_DEAD and __PERCPU_REF_ATOMIC set. The fix is to make the tryget routines use an actual boolean internally instead of the atomic long result truncated to a int. Fixes: e625305b3907 percpu-refcount: make percpu_ref based on longs instead of ints Link: https://bugzilla.kernel.org/show_bug.cgi?id=190751 Signed-off-by: Douglas Miller <dougmill@linux.vnet.ibm.com> Reviewed-by: Jens Axboe <axboe@fb.com> Signed-off-by: Tejun Heo <tj@kernel.org> Fixes: e625305b3907 ("percpu-refcount: make percpu_ref based on longs instead of ints") Cc: stable@vger.kernel.org # v3.18+
Diffstat (limited to 'net/dccp/ccids/ccid3.c')