Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

Merge tags 'ib-mfd-hwmon-v4.18', 'ib-mfd-input-rtc-v4.18' and 'ib-mfd-pwm-v4.18' into ibs-for-mfd-merged

Immutable branch between MFD and HWMON due for the v4.18 merge window

Immutable branch between MFD, Input and RTC due for the v4.18 merge window

Immutable branch between MFD and PWM due for the v4.18 merge window

+938 -9
+43
Documentation/devicetree/bindings/input/mtk-pmic-keys.txt
··· 1 + MediaTek MT6397/MT6323 PMIC Keys Device Driver 2 + 3 + There are two key functions provided by MT6397/MT6323 PMIC, pwrkey 4 + and homekey. The key functions are defined as the subnode of the function 5 + node provided by MT6397/MT6323 PMIC that is being defined as one kind 6 + of Muti-Function Device (MFD) 7 + 8 + For MT6397/MT6323 MFD bindings see: 9 + Documentation/devicetree/bindings/mfd/mt6397.txt 10 + 11 + Required properties: 12 + - compatible: "mediatek,mt6397-keys" or "mediatek,mt6323-keys" 13 + - linux,keycodes: See Documentation/devicetree/bindings/input/keys.txt 14 + 15 + Optional Properties: 16 + - wakeup-source: See Documentation/devicetree/bindings/power/wakeup-source.txt 17 + - mediatek,long-press-mode: Long press key shutdown setting, 1 for 18 + pwrkey only, 2 for pwrkey/homekey together, others for disabled. 19 + - power-off-time-sec: See Documentation/devicetree/bindings/input/keys.txt 20 + 21 + Example: 22 + 23 + pmic: mt6397 { 24 + compatible = "mediatek,mt6397"; 25 + 26 + ... 27 + 28 + mt6397keys: mt6397keys { 29 + compatible = "mediatek,mt6397-keys"; 30 + mediatek,long-press-mode = <1>; 31 + power-off-time-sec = <0>; 32 + 33 + power { 34 + linux,keycodes = <116>; 35 + wakeup-source; 36 + }; 37 + 38 + home { 39 + linux,keycodes = <114>; 40 + }; 41 + }; 42 + 43 + };
+6
Documentation/devicetree/bindings/mfd/mt6397.txt
··· 7 7 - GPIO 8 8 - Clock 9 9 - LED 10 + - Keys 10 11 11 12 It is interfaced to host controller using SPI interface by a proprietary hardware 12 13 called PMIC wrapper or pwrap. MT6397/MT6323 MFD is a child device of pwrap. ··· 40 39 Required properties: 41 40 - compatible: "mediatek,mt6323-led" 42 41 see Documentation/devicetree/bindings/leds/leds-mt6323.txt 42 + 43 + - keys 44 + Required properties: 45 + - compatible: "mediatek,mt6397-keys" or "mediatek,mt6323-keys" 46 + see Documentation/devicetree/bindings/input/mtk-pmic-keys.txt 43 47 44 48 Example: 45 49 pwrap: pwrap@1000f000 {
+9
drivers/input/keyboard/Kconfig
··· 747 747 To compile this driver as a module, choose M here: the 748 748 module will be called bcm-keypad. 749 749 750 + config KEYBOARD_MTK_PMIC 751 + tristate "MediaTek PMIC keys support" 752 + depends on MFD_MT6397 753 + help 754 + Say Y here if you want to use the pmic keys (powerkey/homekey). 755 + 756 + To compile this driver as a module, choose M here: the 757 + module will be called pmic-keys. 758 + 750 759 endif
+1
drivers/input/keyboard/Makefile
··· 40 40 obj-$(CONFIG_KEYBOARD_MAX7359) += max7359_keypad.o 41 41 obj-$(CONFIG_KEYBOARD_MCS) += mcs_touchkey.o 42 42 obj-$(CONFIG_KEYBOARD_MPR121) += mpr121_touchkey.o 43 + obj-$(CONFIG_KEYBOARD_MTK_PMIC) += mtk-pmic-keys.o 43 44 obj-$(CONFIG_KEYBOARD_NEWTON) += newtonkbd.o 44 45 obj-$(CONFIG_KEYBOARD_NOMADIK) += nomadik-ske-keypad.o 45 46 obj-$(CONFIG_KEYBOARD_NSPIRE) += nspire-keypad.o
+339
drivers/input/keyboard/mtk-pmic-keys.c
··· 1 + /* 2 + * Copyright (C) 2017 MediaTek, Inc. 3 + * 4 + * Author: Chen Zhong <chen.zhong@mediatek.com> 5 + * 6 + * This software is licensed under the terms of the GNU General Public 7 + * License version 2, as published by the Free Software Foundation, and 8 + * may be copied, distributed, and modified under those terms. 9 + * 10 + * This program is distributed in the hope that it will be useful, 11 + * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 + * GNU General Public License for more details. 14 + * 15 + */ 16 + 17 + #include <linux/module.h> 18 + #include <linux/kernel.h> 19 + #include <linux/input.h> 20 + #include <linux/interrupt.h> 21 + #include <linux/platform_device.h> 22 + #include <linux/kernel.h> 23 + #include <linux/of.h> 24 + #include <linux/of_device.h> 25 + #include <linux/regmap.h> 26 + #include <linux/mfd/mt6323/registers.h> 27 + #include <linux/mfd/mt6397/registers.h> 28 + #include <linux/mfd/mt6397/core.h> 29 + 30 + #define MTK_PMIC_PWRKEY_RST_EN_MASK 0x1 31 + #define MTK_PMIC_PWRKEY_RST_EN_SHIFT 6 32 + #define MTK_PMIC_HOMEKEY_RST_EN_MASK 0x1 33 + #define MTK_PMIC_HOMEKEY_RST_EN_SHIFT 5 34 + #define MTK_PMIC_RST_DU_MASK 0x3 35 + #define MTK_PMIC_RST_DU_SHIFT 8 36 + 37 + #define MTK_PMIC_PWRKEY_RST \ 38 + (MTK_PMIC_PWRKEY_RST_EN_MASK << MTK_PMIC_PWRKEY_RST_EN_SHIFT) 39 + #define MTK_PMIC_HOMEKEY_RST \ 40 + (MTK_PMIC_HOMEKEY_RST_EN_MASK << MTK_PMIC_HOMEKEY_RST_EN_SHIFT) 41 + 42 + #define MTK_PMIC_PWRKEY_INDEX 0 43 + #define MTK_PMIC_HOMEKEY_INDEX 1 44 + #define MTK_PMIC_MAX_KEY_COUNT 2 45 + 46 + struct mtk_pmic_keys_regs { 47 + u32 deb_reg; 48 + u32 deb_mask; 49 + u32 intsel_reg; 50 + u32 intsel_mask; 51 + }; 52 + 53 + #define MTK_PMIC_KEYS_REGS(_deb_reg, _deb_mask, \ 54 + _intsel_reg, _intsel_mask) \ 55 + { \ 56 + .deb_reg = _deb_reg, \ 57 + .deb_mask = _deb_mask, \ 58 + .intsel_reg = _intsel_reg, \ 59 + .intsel_mask = _intsel_mask, \ 60 + } 61 + 62 + struct mtk_pmic_regs { 63 + const struct mtk_pmic_keys_regs keys_regs[MTK_PMIC_MAX_KEY_COUNT]; 64 + u32 pmic_rst_reg; 65 + }; 66 + 67 + static const struct mtk_pmic_regs mt6397_regs = { 68 + .keys_regs[MTK_PMIC_PWRKEY_INDEX] = 69 + MTK_PMIC_KEYS_REGS(MT6397_CHRSTATUS, 70 + 0x8, MT6397_INT_RSV, 0x10), 71 + .keys_regs[MTK_PMIC_HOMEKEY_INDEX] = 72 + MTK_PMIC_KEYS_REGS(MT6397_OCSTATUS2, 73 + 0x10, MT6397_INT_RSV, 0x8), 74 + .pmic_rst_reg = MT6397_TOP_RST_MISC, 75 + }; 76 + 77 + static const struct mtk_pmic_regs mt6323_regs = { 78 + .keys_regs[MTK_PMIC_PWRKEY_INDEX] = 79 + MTK_PMIC_KEYS_REGS(MT6323_CHRSTATUS, 80 + 0x2, MT6323_INT_MISC_CON, 0x10), 81 + .keys_regs[MTK_PMIC_HOMEKEY_INDEX] = 82 + MTK_PMIC_KEYS_REGS(MT6323_CHRSTATUS, 83 + 0x4, MT6323_INT_MISC_CON, 0x8), 84 + .pmic_rst_reg = MT6323_TOP_RST_MISC, 85 + }; 86 + 87 + struct mtk_pmic_keys_info { 88 + struct mtk_pmic_keys *keys; 89 + const struct mtk_pmic_keys_regs *regs; 90 + unsigned int keycode; 91 + int irq; 92 + bool wakeup:1; 93 + }; 94 + 95 + struct mtk_pmic_keys { 96 + struct input_dev *input_dev; 97 + struct device *dev; 98 + struct regmap *regmap; 99 + struct mtk_pmic_keys_info keys[MTK_PMIC_MAX_KEY_COUNT]; 100 + }; 101 + 102 + enum mtk_pmic_keys_lp_mode { 103 + LP_DISABLE, 104 + LP_ONEKEY, 105 + LP_TWOKEY, 106 + }; 107 + 108 + static void mtk_pmic_keys_lp_reset_setup(struct mtk_pmic_keys *keys, 109 + u32 pmic_rst_reg) 110 + { 111 + int ret; 112 + u32 long_press_mode, long_press_debounce; 113 + 114 + ret = of_property_read_u32(keys->dev->of_node, 115 + "power-off-time-sec", &long_press_debounce); 116 + if (ret) 117 + long_press_debounce = 0; 118 + 119 + regmap_update_bits(keys->regmap, pmic_rst_reg, 120 + MTK_PMIC_RST_DU_MASK << MTK_PMIC_RST_DU_SHIFT, 121 + long_press_debounce << MTK_PMIC_RST_DU_SHIFT); 122 + 123 + ret = of_property_read_u32(keys->dev->of_node, 124 + "mediatek,long-press-mode", &long_press_mode); 125 + if (ret) 126 + long_press_mode = LP_DISABLE; 127 + 128 + switch (long_press_mode) { 129 + case LP_ONEKEY: 130 + regmap_update_bits(keys->regmap, pmic_rst_reg, 131 + MTK_PMIC_PWRKEY_RST, 132 + MTK_PMIC_PWRKEY_RST); 133 + regmap_update_bits(keys->regmap, pmic_rst_reg, 134 + MTK_PMIC_HOMEKEY_RST, 135 + 0); 136 + break; 137 + case LP_TWOKEY: 138 + regmap_update_bits(keys->regmap, pmic_rst_reg, 139 + MTK_PMIC_PWRKEY_RST, 140 + MTK_PMIC_PWRKEY_RST); 141 + regmap_update_bits(keys->regmap, pmic_rst_reg, 142 + MTK_PMIC_HOMEKEY_RST, 143 + MTK_PMIC_HOMEKEY_RST); 144 + break; 145 + case LP_DISABLE: 146 + regmap_update_bits(keys->regmap, pmic_rst_reg, 147 + MTK_PMIC_PWRKEY_RST, 148 + 0); 149 + regmap_update_bits(keys->regmap, pmic_rst_reg, 150 + MTK_PMIC_HOMEKEY_RST, 151 + 0); 152 + break; 153 + default: 154 + break; 155 + } 156 + } 157 + 158 + static irqreturn_t mtk_pmic_keys_irq_handler_thread(int irq, void *data) 159 + { 160 + struct mtk_pmic_keys_info *info = data; 161 + u32 key_deb, pressed; 162 + 163 + regmap_read(info->keys->regmap, info->regs->deb_reg, &key_deb); 164 + 165 + key_deb &= info->regs->deb_mask; 166 + 167 + pressed = !key_deb; 168 + 169 + input_report_key(info->keys->input_dev, info->keycode, pressed); 170 + input_sync(info->keys->input_dev); 171 + 172 + dev_dbg(info->keys->dev, "(%s) key =%d using PMIC\n", 173 + pressed ? "pressed" : "released", info->keycode); 174 + 175 + return IRQ_HANDLED; 176 + } 177 + 178 + static int mtk_pmic_key_setup(struct mtk_pmic_keys *keys, 179 + struct mtk_pmic_keys_info *info) 180 + { 181 + int ret; 182 + 183 + info->keys = keys; 184 + 185 + ret = regmap_update_bits(keys->regmap, info->regs->intsel_reg, 186 + info->regs->intsel_mask, 187 + info->regs->intsel_mask); 188 + if (ret < 0) 189 + return ret; 190 + 191 + ret = devm_request_threaded_irq(keys->dev, info->irq, NULL, 192 + mtk_pmic_keys_irq_handler_thread, 193 + IRQF_ONESHOT | IRQF_TRIGGER_HIGH, 194 + "mtk-pmic-keys", info); 195 + if (ret) { 196 + dev_err(keys->dev, "Failed to request IRQ: %d: %d\n", 197 + info->irq, ret); 198 + return ret; 199 + } 200 + 201 + input_set_capability(keys->input_dev, EV_KEY, info->keycode); 202 + 203 + return 0; 204 + } 205 + 206 + static int __maybe_unused mtk_pmic_keys_suspend(struct device *dev) 207 + { 208 + struct mtk_pmic_keys *keys = dev_get_drvdata(dev); 209 + int index; 210 + 211 + for (index = 0; index < MTK_PMIC_MAX_KEY_COUNT; index++) { 212 + if (keys->keys[index].wakeup) 213 + enable_irq_wake(keys->keys[index].irq); 214 + } 215 + 216 + return 0; 217 + } 218 + 219 + static int __maybe_unused mtk_pmic_keys_resume(struct device *dev) 220 + { 221 + struct mtk_pmic_keys *keys = dev_get_drvdata(dev); 222 + int index; 223 + 224 + for (index = 0; index < MTK_PMIC_MAX_KEY_COUNT; index++) { 225 + if (keys->keys[index].wakeup) 226 + disable_irq_wake(keys->keys[index].irq); 227 + } 228 + 229 + return 0; 230 + } 231 + 232 + static SIMPLE_DEV_PM_OPS(mtk_pmic_keys_pm_ops, mtk_pmic_keys_suspend, 233 + mtk_pmic_keys_resume); 234 + 235 + static const struct of_device_id of_mtk_pmic_keys_match_tbl[] = { 236 + { 237 + .compatible = "mediatek,mt6397-keys", 238 + .data = &mt6397_regs, 239 + }, { 240 + .compatible = "mediatek,mt6323-keys", 241 + .data = &mt6323_regs, 242 + }, { 243 + /* sentinel */ 244 + } 245 + }; 246 + MODULE_DEVICE_TABLE(of, of_mtk_pmic_keys_match_tbl); 247 + 248 + static int mtk_pmic_keys_probe(struct platform_device *pdev) 249 + { 250 + int error, index = 0; 251 + unsigned int keycount; 252 + struct mt6397_chip *pmic_chip = dev_get_drvdata(pdev->dev.parent); 253 + struct device_node *node = pdev->dev.of_node, *child; 254 + struct mtk_pmic_keys *keys; 255 + const struct mtk_pmic_regs *mtk_pmic_regs; 256 + struct input_dev *input_dev; 257 + const struct of_device_id *of_id = 258 + of_match_device(of_mtk_pmic_keys_match_tbl, &pdev->dev); 259 + 260 + keys = devm_kzalloc(&pdev->dev, sizeof(*keys), GFP_KERNEL); 261 + if (!keys) 262 + return -ENOMEM; 263 + 264 + keys->dev = &pdev->dev; 265 + keys->regmap = pmic_chip->regmap; 266 + mtk_pmic_regs = of_id->data; 267 + 268 + keys->input_dev = input_dev = devm_input_allocate_device(keys->dev); 269 + if (!input_dev) { 270 + dev_err(keys->dev, "input allocate device fail.\n"); 271 + return -ENOMEM; 272 + } 273 + 274 + input_dev->name = "mtk-pmic-keys"; 275 + input_dev->id.bustype = BUS_HOST; 276 + input_dev->id.vendor = 0x0001; 277 + input_dev->id.product = 0x0001; 278 + input_dev->id.version = 0x0001; 279 + 280 + keycount = of_get_available_child_count(node); 281 + if (keycount > MTK_PMIC_MAX_KEY_COUNT) { 282 + dev_err(keys->dev, "too many keys defined (%d)\n", keycount); 283 + return -EINVAL; 284 + } 285 + 286 + for_each_child_of_node(node, child) { 287 + keys->keys[index].regs = &mtk_pmic_regs->keys_regs[index]; 288 + 289 + keys->keys[index].irq = platform_get_irq(pdev, index); 290 + if (keys->keys[index].irq < 0) 291 + return keys->keys[index].irq; 292 + 293 + error = of_property_read_u32(child, 294 + "linux,keycodes", &keys->keys[index].keycode); 295 + if (error) { 296 + dev_err(keys->dev, 297 + "failed to read key:%d linux,keycode property: %d\n", 298 + index, error); 299 + return error; 300 + } 301 + 302 + if (of_property_read_bool(child, "wakeup-source")) 303 + keys->keys[index].wakeup = true; 304 + 305 + error = mtk_pmic_key_setup(keys, &keys->keys[index]); 306 + if (error) 307 + return error; 308 + 309 + index++; 310 + } 311 + 312 + error = input_register_device(input_dev); 313 + if (error) { 314 + dev_err(&pdev->dev, 315 + "register input device failed (%d)\n", error); 316 + return error; 317 + } 318 + 319 + mtk_pmic_keys_lp_reset_setup(keys, mtk_pmic_regs->pmic_rst_reg); 320 + 321 + platform_set_drvdata(pdev, keys); 322 + 323 + return 0; 324 + } 325 + 326 + static struct platform_driver pmic_keys_pdrv = { 327 + .probe = mtk_pmic_keys_probe, 328 + .driver = { 329 + .name = "mtk-pmic-keys", 330 + .of_match_table = of_mtk_pmic_keys_match_tbl, 331 + .pm = &mtk_pmic_keys_pm_ops, 332 + }, 333 + }; 334 + 335 + module_platform_driver(pmic_keys_pdrv); 336 + 337 + MODULE_LICENSE("GPL v2"); 338 + MODULE_AUTHOR("Chen Zhong <chen.zhong@mediatek.com>"); 339 + MODULE_DESCRIPTION("MTK pmic-keys driver v0.1");
+23 -3
drivers/mfd/mt6397-core.c
··· 43 43 }, 44 44 }; 45 45 46 + static const struct resource mt6323_keys_resources[] = { 47 + DEFINE_RES_IRQ(MT6323_IRQ_STATUS_PWRKEY), 48 + DEFINE_RES_IRQ(MT6323_IRQ_STATUS_FCHRKEY), 49 + }; 50 + 51 + static const struct resource mt6397_keys_resources[] = { 52 + DEFINE_RES_IRQ(MT6397_IRQ_PWRKEY), 53 + DEFINE_RES_IRQ(MT6397_IRQ_HOMEKEY), 54 + }; 55 + 46 56 static const struct mfd_cell mt6323_devs[] = { 47 57 { 48 58 .name = "mt6323-regulator", ··· 60 50 }, { 61 51 .name = "mt6323-led", 62 52 .of_compatible = "mediatek,mt6323-led" 53 + }, { 54 + .name = "mtk-pmic-keys", 55 + .num_resources = ARRAY_SIZE(mt6323_keys_resources), 56 + .resources = mt6323_keys_resources, 57 + .of_compatible = "mediatek,mt6323-keys" 63 58 }, 64 59 }; 65 60 ··· 86 71 }, { 87 72 .name = "mt6397-pinctrl", 88 73 .of_compatible = "mediatek,mt6397-pinctrl", 89 - }, 74 + }, { 75 + .name = "mtk-pmic-keys", 76 + .num_resources = ARRAY_SIZE(mt6397_keys_resources), 77 + .resources = mt6397_keys_resources, 78 + .of_compatible = "mediatek,mt6397-keys" 79 + } 90 80 }; 91 81 92 82 static void mt6397_irq_lock(struct irq_data *data) ··· 309 289 310 290 ret = devm_mfd_add_devices(&pdev->dev, -1, mt6323_devs, 311 291 ARRAY_SIZE(mt6323_devs), NULL, 312 - 0, NULL); 292 + 0, pmic->irq_domain); 313 293 break; 314 294 315 295 case MT6397_CID_CODE: ··· 324 304 325 305 ret = devm_mfd_add_devices(&pdev->dev, -1, mt6397_devs, 326 306 ARRAY_SIZE(mt6397_devs), NULL, 327 - 0, NULL); 307 + 0, pmic->irq_domain); 328 308 break; 329 309 330 310 default:
+199 -2
drivers/mfd/stm32-timers.c
··· 4 4 * Author: Benjamin Gaignard <benjamin.gaignard@st.com> 5 5 */ 6 6 7 + #include <linux/bitfield.h> 7 8 #include <linux/mfd/stm32-timers.h> 8 9 #include <linux/module.h> 9 10 #include <linux/of_platform.h> 10 11 #include <linux/reset.h> 11 12 13 + #define STM32_TIMERS_MAX_REGISTERS 0x3fc 14 + 15 + /* DIER register DMA enable bits */ 16 + static const u32 stm32_timers_dier_dmaen[STM32_TIMERS_MAX_DMAS] = { 17 + TIM_DIER_CC1DE, 18 + TIM_DIER_CC2DE, 19 + TIM_DIER_CC3DE, 20 + TIM_DIER_CC4DE, 21 + TIM_DIER_UIE, 22 + TIM_DIER_TDE, 23 + TIM_DIER_COMDE 24 + }; 25 + 26 + static void stm32_timers_dma_done(void *p) 27 + { 28 + struct stm32_timers_dma *dma = p; 29 + struct dma_tx_state state; 30 + enum dma_status status; 31 + 32 + status = dmaengine_tx_status(dma->chan, dma->chan->cookie, &state); 33 + if (status == DMA_COMPLETE) 34 + complete(&dma->completion); 35 + } 36 + 37 + /** 38 + * stm32_timers_dma_burst_read - Read from timers registers using DMA. 39 + * 40 + * Read from STM32 timers registers using DMA on a single event. 41 + * @dev: reference to stm32_timers MFD device 42 + * @buf: DMA'able destination buffer 43 + * @id: stm32_timers_dmas event identifier (ch[1..4], up, trig or com) 44 + * @reg: registers start offset for DMA to read from (like CCRx for capture) 45 + * @num_reg: number of registers to read upon each DMA request, starting @reg. 46 + * @bursts: number of bursts to read (e.g. like two for pwm period capture) 47 + * @tmo_ms: timeout (milliseconds) 48 + */ 49 + int stm32_timers_dma_burst_read(struct device *dev, u32 *buf, 50 + enum stm32_timers_dmas id, u32 reg, 51 + unsigned int num_reg, unsigned int bursts, 52 + unsigned long tmo_ms) 53 + { 54 + struct stm32_timers *ddata = dev_get_drvdata(dev); 55 + unsigned long timeout = msecs_to_jiffies(tmo_ms); 56 + struct regmap *regmap = ddata->regmap; 57 + struct stm32_timers_dma *dma = &ddata->dma; 58 + size_t len = num_reg * bursts * sizeof(u32); 59 + struct dma_async_tx_descriptor *desc; 60 + struct dma_slave_config config; 61 + dma_cookie_t cookie; 62 + dma_addr_t dma_buf; 63 + u32 dbl, dba; 64 + long err; 65 + int ret; 66 + 67 + /* Sanity check */ 68 + if (id < STM32_TIMERS_DMA_CH1 || id >= STM32_TIMERS_MAX_DMAS) 69 + return -EINVAL; 70 + 71 + if (!num_reg || !bursts || reg > STM32_TIMERS_MAX_REGISTERS || 72 + (reg + num_reg * sizeof(u32)) > STM32_TIMERS_MAX_REGISTERS) 73 + return -EINVAL; 74 + 75 + if (!dma->chans[id]) 76 + return -ENODEV; 77 + mutex_lock(&dma->lock); 78 + 79 + /* Select DMA channel in use */ 80 + dma->chan = dma->chans[id]; 81 + dma_buf = dma_map_single(dev, buf, len, DMA_FROM_DEVICE); 82 + if (dma_mapping_error(dev, dma_buf)) { 83 + ret = -ENOMEM; 84 + goto unlock; 85 + } 86 + 87 + /* Prepare DMA read from timer registers, using DMA burst mode */ 88 + memset(&config, 0, sizeof(config)); 89 + config.src_addr = (dma_addr_t)dma->phys_base + TIM_DMAR; 90 + config.src_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; 91 + ret = dmaengine_slave_config(dma->chan, &config); 92 + if (ret) 93 + goto unmap; 94 + 95 + desc = dmaengine_prep_slave_single(dma->chan, dma_buf, len, 96 + DMA_DEV_TO_MEM, DMA_PREP_INTERRUPT); 97 + if (!desc) { 98 + ret = -EBUSY; 99 + goto unmap; 100 + } 101 + 102 + desc->callback = stm32_timers_dma_done; 103 + desc->callback_param = dma; 104 + cookie = dmaengine_submit(desc); 105 + ret = dma_submit_error(cookie); 106 + if (ret) 107 + goto dma_term; 108 + 109 + reinit_completion(&dma->completion); 110 + dma_async_issue_pending(dma->chan); 111 + 112 + /* Setup and enable timer DMA burst mode */ 113 + dbl = FIELD_PREP(TIM_DCR_DBL, bursts - 1); 114 + dba = FIELD_PREP(TIM_DCR_DBA, reg >> 2); 115 + ret = regmap_write(regmap, TIM_DCR, dbl | dba); 116 + if (ret) 117 + goto dma_term; 118 + 119 + /* Clear pending flags before enabling DMA request */ 120 + ret = regmap_write(regmap, TIM_SR, 0); 121 + if (ret) 122 + goto dcr_clr; 123 + 124 + ret = regmap_update_bits(regmap, TIM_DIER, stm32_timers_dier_dmaen[id], 125 + stm32_timers_dier_dmaen[id]); 126 + if (ret) 127 + goto dcr_clr; 128 + 129 + err = wait_for_completion_interruptible_timeout(&dma->completion, 130 + timeout); 131 + if (err == 0) 132 + ret = -ETIMEDOUT; 133 + else if (err < 0) 134 + ret = err; 135 + 136 + regmap_update_bits(regmap, TIM_DIER, stm32_timers_dier_dmaen[id], 0); 137 + regmap_write(regmap, TIM_SR, 0); 138 + dcr_clr: 139 + regmap_write(regmap, TIM_DCR, 0); 140 + dma_term: 141 + dmaengine_terminate_all(dma->chan); 142 + unmap: 143 + dma_unmap_single(dev, dma_buf, len, DMA_FROM_DEVICE); 144 + unlock: 145 + dma->chan = NULL; 146 + mutex_unlock(&dma->lock); 147 + 148 + return ret; 149 + } 150 + EXPORT_SYMBOL_GPL(stm32_timers_dma_burst_read); 151 + 12 152 static const struct regmap_config stm32_timers_regmap_cfg = { 13 153 .reg_bits = 32, 14 154 .val_bits = 32, 15 155 .reg_stride = sizeof(u32), 16 - .max_register = 0x3fc, 156 + .max_register = STM32_TIMERS_MAX_REGISTERS, 17 157 }; 18 158 19 159 static void stm32_timers_get_arr_size(struct stm32_timers *ddata) ··· 167 27 regmap_write(ddata->regmap, TIM_ARR, 0x0); 168 28 } 169 29 30 + static void stm32_timers_dma_probe(struct device *dev, 31 + struct stm32_timers *ddata) 32 + { 33 + int i; 34 + char name[4]; 35 + 36 + init_completion(&ddata->dma.completion); 37 + mutex_init(&ddata->dma.lock); 38 + 39 + /* Optional DMA support: get valid DMA channel(s) or NULL */ 40 + for (i = STM32_TIMERS_DMA_CH1; i <= STM32_TIMERS_DMA_CH4; i++) { 41 + snprintf(name, ARRAY_SIZE(name), "ch%1d", i + 1); 42 + ddata->dma.chans[i] = dma_request_slave_channel(dev, name); 43 + } 44 + ddata->dma.chans[STM32_TIMERS_DMA_UP] = 45 + dma_request_slave_channel(dev, "up"); 46 + ddata->dma.chans[STM32_TIMERS_DMA_TRIG] = 47 + dma_request_slave_channel(dev, "trig"); 48 + ddata->dma.chans[STM32_TIMERS_DMA_COM] = 49 + dma_request_slave_channel(dev, "com"); 50 + } 51 + 52 + static void stm32_timers_dma_remove(struct device *dev, 53 + struct stm32_timers *ddata) 54 + { 55 + int i; 56 + 57 + for (i = STM32_TIMERS_DMA_CH1; i < STM32_TIMERS_MAX_DMAS; i++) 58 + if (ddata->dma.chans[i]) 59 + dma_release_channel(ddata->dma.chans[i]); 60 + } 61 + 170 62 static int stm32_timers_probe(struct platform_device *pdev) 171 63 { 172 64 struct device *dev = &pdev->dev; 173 65 struct stm32_timers *ddata; 174 66 struct resource *res; 175 67 void __iomem *mmio; 68 + int ret; 176 69 177 70 ddata = devm_kzalloc(dev, sizeof(*ddata), GFP_KERNEL); 178 71 if (!ddata) ··· 215 42 mmio = devm_ioremap_resource(dev, res); 216 43 if (IS_ERR(mmio)) 217 44 return PTR_ERR(mmio); 45 + 46 + /* Timer physical addr for DMA */ 47 + ddata->dma.phys_base = res->start; 218 48 219 49 ddata->regmap = devm_regmap_init_mmio_clk(dev, "int", mmio, 220 50 &stm32_timers_regmap_cfg); ··· 230 54 231 55 stm32_timers_get_arr_size(ddata); 232 56 57 + stm32_timers_dma_probe(dev, ddata); 58 + 233 59 platform_set_drvdata(pdev, ddata); 234 60 235 - return devm_of_platform_populate(&pdev->dev); 61 + ret = of_platform_populate(pdev->dev.of_node, NULL, NULL, &pdev->dev); 62 + if (ret) 63 + stm32_timers_dma_remove(dev, ddata); 64 + 65 + return ret; 66 + } 67 + 68 + static int stm32_timers_remove(struct platform_device *pdev) 69 + { 70 + struct stm32_timers *ddata = platform_get_drvdata(pdev); 71 + 72 + /* 73 + * Don't use devm_ here: enfore of_platform_depopulate() happens before 74 + * DMA are released, to avoid race on DMA. 75 + */ 76 + of_platform_depopulate(&pdev->dev); 77 + stm32_timers_dma_remove(&pdev->dev, ddata); 78 + 79 + return 0; 236 80 } 237 81 238 82 static const struct of_device_id stm32_timers_of_match[] = { ··· 263 67 264 68 static struct platform_driver stm32_timers_driver = { 265 69 .probe = stm32_timers_probe, 70 + .remove = stm32_timers_remove, 266 71 .driver = { 267 72 .name = "stm32-timers", 268 73 .of_match_table = stm32_timers_of_match,
+257
drivers/pwm/pwm-stm32.c
··· 8 8 * pwm-atmel.c from Bo Shen 9 9 */ 10 10 11 + #include <linux/bitfield.h> 11 12 #include <linux/mfd/stm32-timers.h> 12 13 #include <linux/module.h> 13 14 #include <linux/of.h> ··· 26 25 struct regmap *regmap; 27 26 u32 max_arr; 28 27 bool have_complementary_output; 28 + u32 capture[4] ____cacheline_aligned; /* DMA'able buffer */ 29 29 }; 30 30 31 31 struct stm32_breakinput { ··· 62 60 return regmap_write(dev->regmap, TIM_CCR4, value); 63 61 } 64 62 return -EINVAL; 63 + } 64 + 65 + #define TIM_CCER_CC12P (TIM_CCER_CC1P | TIM_CCER_CC2P) 66 + #define TIM_CCER_CC12E (TIM_CCER_CC1E | TIM_CCER_CC2E) 67 + #define TIM_CCER_CC34P (TIM_CCER_CC3P | TIM_CCER_CC4P) 68 + #define TIM_CCER_CC34E (TIM_CCER_CC3E | TIM_CCER_CC4E) 69 + 70 + /* 71 + * Capture using PWM input mode: 72 + * ___ ___ 73 + * TI[1, 2, 3 or 4]: ........._| |________| 74 + * ^0 ^1 ^2 75 + * . . . 76 + * . . XXXXX 77 + * . . XXXXX | 78 + * . XXXXX . | 79 + * XXXXX . . | 80 + * COUNTER: ______XXXXX . . . |_XXX 81 + * start^ . . . ^stop 82 + * . . . . 83 + * v v . v 84 + * v 85 + * CCR1/CCR3: tx..........t0...........t2 86 + * CCR2/CCR4: tx..............t1......... 87 + * 88 + * DMA burst transfer: | | 89 + * v v 90 + * DMA buffer: { t0, tx } { t2, t1 } 91 + * DMA done: ^ 92 + * 93 + * 0: IC1/3 snapchot on rising edge: counter value -> CCR1/CCR3 94 + * + DMA transfer CCR[1/3] & CCR[2/4] values (t0, tx: doesn't care) 95 + * 1: IC2/4 snapchot on falling edge: counter value -> CCR2/CCR4 96 + * 2: IC1/3 snapchot on rising edge: counter value -> CCR1/CCR3 97 + * + DMA transfer CCR[1/3] & CCR[2/4] values (t2, t1) 98 + * 99 + * DMA done, compute: 100 + * - Period = t2 - t0 101 + * - Duty cycle = t1 - t0 102 + */ 103 + static int stm32_pwm_raw_capture(struct stm32_pwm *priv, struct pwm_device *pwm, 104 + unsigned long tmo_ms, u32 *raw_prd, 105 + u32 *raw_dty) 106 + { 107 + struct device *parent = priv->chip.dev->parent; 108 + enum stm32_timers_dmas dma_id; 109 + u32 ccen, ccr; 110 + int ret; 111 + 112 + /* Ensure registers have been updated, enable counter and capture */ 113 + regmap_update_bits(priv->regmap, TIM_EGR, TIM_EGR_UG, TIM_EGR_UG); 114 + regmap_update_bits(priv->regmap, TIM_CR1, TIM_CR1_CEN, TIM_CR1_CEN); 115 + 116 + /* Use cc1 or cc3 DMA resp for PWM input channels 1 & 2 or 3 & 4 */ 117 + dma_id = pwm->hwpwm < 2 ? STM32_TIMERS_DMA_CH1 : STM32_TIMERS_DMA_CH3; 118 + ccen = pwm->hwpwm < 2 ? TIM_CCER_CC12E : TIM_CCER_CC34E; 119 + ccr = pwm->hwpwm < 2 ? TIM_CCR1 : TIM_CCR3; 120 + regmap_update_bits(priv->regmap, TIM_CCER, ccen, ccen); 121 + 122 + /* 123 + * Timer DMA burst mode. Request 2 registers, 2 bursts, to get both 124 + * CCR1 & CCR2 (or CCR3 & CCR4) on each capture event. 125 + * We'll get two capture snapchots: { CCR1, CCR2 }, { CCR1, CCR2 } 126 + * or { CCR3, CCR4 }, { CCR3, CCR4 } 127 + */ 128 + ret = stm32_timers_dma_burst_read(parent, priv->capture, dma_id, ccr, 2, 129 + 2, tmo_ms); 130 + if (ret) 131 + goto stop; 132 + 133 + /* Period: t2 - t0 (take care of counter overflow) */ 134 + if (priv->capture[0] <= priv->capture[2]) 135 + *raw_prd = priv->capture[2] - priv->capture[0]; 136 + else 137 + *raw_prd = priv->max_arr - priv->capture[0] + priv->capture[2]; 138 + 139 + /* Duty cycle capture requires at least two capture units */ 140 + if (pwm->chip->npwm < 2) 141 + *raw_dty = 0; 142 + else if (priv->capture[0] <= priv->capture[3]) 143 + *raw_dty = priv->capture[3] - priv->capture[0]; 144 + else 145 + *raw_dty = priv->max_arr - priv->capture[0] + priv->capture[3]; 146 + 147 + if (*raw_dty > *raw_prd) { 148 + /* 149 + * Race beetween PWM input and DMA: it may happen 150 + * falling edge triggers new capture on TI2/4 before DMA 151 + * had a chance to read CCR2/4. It means capture[1] 152 + * contains period + duty_cycle. So, subtract period. 153 + */ 154 + *raw_dty -= *raw_prd; 155 + } 156 + 157 + stop: 158 + regmap_update_bits(priv->regmap, TIM_CCER, ccen, 0); 159 + regmap_update_bits(priv->regmap, TIM_CR1, TIM_CR1_CEN, 0); 160 + 161 + return ret; 162 + } 163 + 164 + static int stm32_pwm_capture(struct pwm_chip *chip, struct pwm_device *pwm, 165 + struct pwm_capture *result, unsigned long tmo_ms) 166 + { 167 + struct stm32_pwm *priv = to_stm32_pwm_dev(chip); 168 + unsigned long long prd, div, dty; 169 + unsigned long rate; 170 + unsigned int psc = 0, icpsc, scale; 171 + u32 raw_prd, raw_dty; 172 + int ret = 0; 173 + 174 + mutex_lock(&priv->lock); 175 + 176 + if (active_channels(priv)) { 177 + ret = -EBUSY; 178 + goto unlock; 179 + } 180 + 181 + ret = clk_enable(priv->clk); 182 + if (ret) { 183 + dev_err(priv->chip.dev, "failed to enable counter clock\n"); 184 + goto unlock; 185 + } 186 + 187 + rate = clk_get_rate(priv->clk); 188 + if (!rate) { 189 + ret = -EINVAL; 190 + goto clk_dis; 191 + } 192 + 193 + /* prescaler: fit timeout window provided by upper layer */ 194 + div = (unsigned long long)rate * (unsigned long long)tmo_ms; 195 + do_div(div, MSEC_PER_SEC); 196 + prd = div; 197 + while ((div > priv->max_arr) && (psc < MAX_TIM_PSC)) { 198 + psc++; 199 + div = prd; 200 + do_div(div, psc + 1); 201 + } 202 + regmap_write(priv->regmap, TIM_ARR, priv->max_arr); 203 + regmap_write(priv->regmap, TIM_PSC, psc); 204 + 205 + /* Map TI1 or TI2 PWM input to IC1 & IC2 (or TI3/4 to IC3 & IC4) */ 206 + regmap_update_bits(priv->regmap, 207 + pwm->hwpwm < 2 ? TIM_CCMR1 : TIM_CCMR2, 208 + TIM_CCMR_CC1S | TIM_CCMR_CC2S, pwm->hwpwm & 0x1 ? 209 + TIM_CCMR_CC1S_TI2 | TIM_CCMR_CC2S_TI2 : 210 + TIM_CCMR_CC1S_TI1 | TIM_CCMR_CC2S_TI1); 211 + 212 + /* Capture period on IC1/3 rising edge, duty cycle on IC2/4 falling. */ 213 + regmap_update_bits(priv->regmap, TIM_CCER, pwm->hwpwm < 2 ? 214 + TIM_CCER_CC12P : TIM_CCER_CC34P, pwm->hwpwm < 2 ? 215 + TIM_CCER_CC2P : TIM_CCER_CC4P); 216 + 217 + ret = stm32_pwm_raw_capture(priv, pwm, tmo_ms, &raw_prd, &raw_dty); 218 + if (ret) 219 + goto stop; 220 + 221 + /* 222 + * Got a capture. Try to improve accuracy at high rates: 223 + * - decrease counter clock prescaler, scale up to max rate. 224 + * - use input prescaler, capture once every /2 /4 or /8 edges. 225 + */ 226 + if (raw_prd) { 227 + u32 max_arr = priv->max_arr - 0x1000; /* arbitrary margin */ 228 + 229 + scale = max_arr / min(max_arr, raw_prd); 230 + } else { 231 + scale = priv->max_arr; /* bellow resolution, use max scale */ 232 + } 233 + 234 + if (psc && scale > 1) { 235 + /* 2nd measure with new scale */ 236 + psc /= scale; 237 + regmap_write(priv->regmap, TIM_PSC, psc); 238 + ret = stm32_pwm_raw_capture(priv, pwm, tmo_ms, &raw_prd, 239 + &raw_dty); 240 + if (ret) 241 + goto stop; 242 + } 243 + 244 + /* Compute intermediate period not to exceed timeout at low rates */ 245 + prd = (unsigned long long)raw_prd * (psc + 1) * NSEC_PER_SEC; 246 + do_div(prd, rate); 247 + 248 + for (icpsc = 0; icpsc < MAX_TIM_ICPSC ; icpsc++) { 249 + /* input prescaler: also keep arbitrary margin */ 250 + if (raw_prd >= (priv->max_arr - 0x1000) >> (icpsc + 1)) 251 + break; 252 + if (prd >= (tmo_ms * NSEC_PER_MSEC) >> (icpsc + 2)) 253 + break; 254 + } 255 + 256 + if (!icpsc) 257 + goto done; 258 + 259 + /* Last chance to improve period accuracy, using input prescaler */ 260 + regmap_update_bits(priv->regmap, 261 + pwm->hwpwm < 2 ? TIM_CCMR1 : TIM_CCMR2, 262 + TIM_CCMR_IC1PSC | TIM_CCMR_IC2PSC, 263 + FIELD_PREP(TIM_CCMR_IC1PSC, icpsc) | 264 + FIELD_PREP(TIM_CCMR_IC2PSC, icpsc)); 265 + 266 + ret = stm32_pwm_raw_capture(priv, pwm, tmo_ms, &raw_prd, &raw_dty); 267 + if (ret) 268 + goto stop; 269 + 270 + if (raw_dty >= (raw_prd >> icpsc)) { 271 + /* 272 + * We may fall here using input prescaler, when input 273 + * capture starts on high side (before falling edge). 274 + * Example with icpsc to capture on each 4 events: 275 + * 276 + * start 1st capture 2nd capture 277 + * v v v 278 + * ___ _____ _____ _____ _____ ____ 279 + * TI1..4 |__| |__| |__| |__| |__| 280 + * v v . . . . . v v 281 + * icpsc1/3: . 0 . 1 . 2 . 3 . 0 282 + * icpsc2/4: 0 1 2 3 0 283 + * v v v v 284 + * CCR1/3 ......t0..............................t2 285 + * CCR2/4 ..t1..............................t1'... 286 + * . . . 287 + * Capture0: .<----------------------------->. 288 + * Capture1: .<-------------------------->. . 289 + * . . . 290 + * Period: .<------> . . 291 + * Low side: .<>. 292 + * 293 + * Result: 294 + * - Period = Capture0 / icpsc 295 + * - Duty = Period - Low side = Period - (Capture0 - Capture1) 296 + */ 297 + raw_dty = (raw_prd >> icpsc) - (raw_prd - raw_dty); 298 + } 299 + 300 + done: 301 + prd = (unsigned long long)raw_prd * (psc + 1) * NSEC_PER_SEC; 302 + result->period = DIV_ROUND_UP_ULL(prd, rate << icpsc); 303 + dty = (unsigned long long)raw_dty * (psc + 1) * NSEC_PER_SEC; 304 + result->duty_cycle = DIV_ROUND_UP_ULL(dty, rate); 305 + stop: 306 + regmap_write(priv->regmap, TIM_CCER, 0); 307 + regmap_write(priv->regmap, pwm->hwpwm < 2 ? TIM_CCMR1 : TIM_CCMR2, 0); 308 + regmap_write(priv->regmap, TIM_PSC, 0); 309 + clk_dis: 310 + clk_disable(priv->clk); 311 + unlock: 312 + mutex_unlock(&priv->lock); 313 + 314 + return ret; 65 315 } 66 316 67 317 static int stm32_pwm_config(struct stm32_pwm *priv, int ch, ··· 484 230 static const struct pwm_ops stm32pwm_ops = { 485 231 .owner = THIS_MODULE, 486 232 .apply = stm32_pwm_apply_locked, 233 + #if IS_ENABLED(CONFIG_DMA_ENGINE) 234 + .capture = stm32_pwm_capture, 235 + #endif 487 236 }; 488 237 489 238 static int stm32_pwm_set_breakinput(struct stm32_pwm *priv,
+3 -4
drivers/rtc/rtc-mt6397.c
··· 322 322 res = platform_get_resource(pdev, IORESOURCE_MEM, 0); 323 323 rtc->addr_base = res->start; 324 324 325 - res = platform_get_resource(pdev, IORESOURCE_IRQ, 0); 326 - rtc->irq = irq_create_mapping(mt6397_chip->irq_domain, res->start); 327 - if (rtc->irq <= 0) 328 - return -EINVAL; 325 + rtc->irq = platform_get_irq(pdev, 0); 326 + if (rtc->irq < 0) 327 + return rtc->irq; 329 328 330 329 rtc->regmap = mt6397_chip->regmap; 331 330 rtc->dev = &pdev->dev;
+58
include/linux/mfd/stm32-timers.h
··· 8 8 #define _LINUX_STM32_GPTIMER_H_ 9 9 10 10 #include <linux/clk.h> 11 + #include <linux/dmaengine.h> 12 + #include <linux/dma-mapping.h> 11 13 #include <linux/regmap.h> 12 14 13 15 #define TIM_CR1 0x00 /* Control Register 1 */ ··· 29 27 #define TIM_CCR3 0x3C /* Capt/Comp Register 3 */ 30 28 #define TIM_CCR4 0x40 /* Capt/Comp Register 4 */ 31 29 #define TIM_BDTR 0x44 /* Break and Dead-Time Reg */ 30 + #define TIM_DCR 0x48 /* DMA control register */ 31 + #define TIM_DMAR 0x4C /* DMA register for transfer */ 32 32 33 33 #define TIM_CR1_CEN BIT(0) /* Counter Enable */ 34 34 #define TIM_CR1_DIR BIT(4) /* Counter Direction */ ··· 40 36 #define TIM_SMCR_SMS (BIT(0) | BIT(1) | BIT(2)) /* Slave mode selection */ 41 37 #define TIM_SMCR_TS (BIT(4) | BIT(5) | BIT(6)) /* Trigger selection */ 42 38 #define TIM_DIER_UIE BIT(0) /* Update interrupt */ 39 + #define TIM_DIER_UDE BIT(8) /* Update DMA request Enable */ 40 + #define TIM_DIER_CC1DE BIT(9) /* CC1 DMA request Enable */ 41 + #define TIM_DIER_CC2DE BIT(10) /* CC2 DMA request Enable */ 42 + #define TIM_DIER_CC3DE BIT(11) /* CC3 DMA request Enable */ 43 + #define TIM_DIER_CC4DE BIT(12) /* CC4 DMA request Enable */ 44 + #define TIM_DIER_COMDE BIT(13) /* COM DMA request Enable */ 45 + #define TIM_DIER_TDE BIT(14) /* Trigger DMA request Enable */ 43 46 #define TIM_SR_UIF BIT(0) /* Update interrupt flag */ 44 47 #define TIM_EGR_UG BIT(0) /* Update Generation */ 45 48 #define TIM_CCMR_PE BIT(3) /* Channel Preload Enable */ 46 49 #define TIM_CCMR_M1 (BIT(6) | BIT(5)) /* Channel PWM Mode 1 */ 50 + #define TIM_CCMR_CC1S (BIT(0) | BIT(1)) /* Capture/compare 1 sel */ 51 + #define TIM_CCMR_IC1PSC GENMASK(3, 2) /* Input capture 1 prescaler */ 52 + #define TIM_CCMR_CC2S (BIT(8) | BIT(9)) /* Capture/compare 2 sel */ 53 + #define TIM_CCMR_IC2PSC GENMASK(11, 10) /* Input capture 2 prescaler */ 54 + #define TIM_CCMR_CC1S_TI1 BIT(0) /* IC1/IC3 selects TI1/TI3 */ 55 + #define TIM_CCMR_CC1S_TI2 BIT(1) /* IC1/IC3 selects TI2/TI4 */ 56 + #define TIM_CCMR_CC2S_TI2 BIT(8) /* IC2/IC4 selects TI2/TI4 */ 57 + #define TIM_CCMR_CC2S_TI1 BIT(9) /* IC2/IC4 selects TI1/TI3 */ 47 58 #define TIM_CCER_CC1E BIT(0) /* Capt/Comp 1 out Ena */ 48 59 #define TIM_CCER_CC1P BIT(1) /* Capt/Comp 1 Polarity */ 49 60 #define TIM_CCER_CC1NE BIT(2) /* Capt/Comp 1N out Ena */ 50 61 #define TIM_CCER_CC1NP BIT(3) /* Capt/Comp 1N Polarity */ 51 62 #define TIM_CCER_CC2E BIT(4) /* Capt/Comp 2 out Ena */ 63 + #define TIM_CCER_CC2P BIT(5) /* Capt/Comp 2 Polarity */ 52 64 #define TIM_CCER_CC3E BIT(8) /* Capt/Comp 3 out Ena */ 65 + #define TIM_CCER_CC3P BIT(9) /* Capt/Comp 3 Polarity */ 53 66 #define TIM_CCER_CC4E BIT(12) /* Capt/Comp 4 out Ena */ 67 + #define TIM_CCER_CC4P BIT(13) /* Capt/Comp 4 Polarity */ 54 68 #define TIM_CCER_CCXE (BIT(0) | BIT(4) | BIT(8) | BIT(12)) 55 69 #define TIM_BDTR_BKE BIT(12) /* Break input enable */ 56 70 #define TIM_BDTR_BKP BIT(13) /* Break input polarity */ ··· 78 56 #define TIM_BDTR_BK2F (BIT(20) | BIT(21) | BIT(22) | BIT(23)) 79 57 #define TIM_BDTR_BK2E BIT(24) /* Break 2 input enable */ 80 58 #define TIM_BDTR_BK2P BIT(25) /* Break 2 input polarity */ 59 + #define TIM_DCR_DBA GENMASK(4, 0) /* DMA base addr */ 60 + #define TIM_DCR_DBL GENMASK(12, 8) /* DMA burst len */ 81 61 82 62 #define MAX_TIM_PSC 0xFFFF 63 + #define MAX_TIM_ICPSC 0x3 83 64 #define TIM_CR2_MMS_SHIFT 4 84 65 #define TIM_CR2_MMS2_SHIFT 20 85 66 #define TIM_SMCR_TS_SHIFT 4 ··· 90 65 #define TIM_BDTR_BKF_SHIFT 16 91 66 #define TIM_BDTR_BK2F_SHIFT 20 92 67 68 + enum stm32_timers_dmas { 69 + STM32_TIMERS_DMA_CH1, 70 + STM32_TIMERS_DMA_CH2, 71 + STM32_TIMERS_DMA_CH3, 72 + STM32_TIMERS_DMA_CH4, 73 + STM32_TIMERS_DMA_UP, 74 + STM32_TIMERS_DMA_TRIG, 75 + STM32_TIMERS_DMA_COM, 76 + STM32_TIMERS_MAX_DMAS, 77 + }; 78 + 79 + /** 80 + * struct stm32_timers_dma - STM32 timer DMA handling. 81 + * @completion: end of DMA transfer completion 82 + * @phys_base: control registers physical base address 83 + * @lock: protect DMA access 84 + * @chan: DMA channel in use 85 + * @chans: DMA channels available for this timer instance 86 + */ 87 + struct stm32_timers_dma { 88 + struct completion completion; 89 + phys_addr_t phys_base; 90 + struct mutex lock; 91 + struct dma_chan *chan; 92 + struct dma_chan *chans[STM32_TIMERS_MAX_DMAS]; 93 + }; 94 + 93 95 struct stm32_timers { 94 96 struct clk *clk; 95 97 struct regmap *regmap; 96 98 u32 max_arr; 99 + struct stm32_timers_dma dma; /* Only to be used by the parent */ 97 100 }; 101 + 102 + int stm32_timers_dma_burst_read(struct device *dev, u32 *buf, 103 + enum stm32_timers_dmas id, u32 reg, 104 + unsigned int num_reg, unsigned int bursts, 105 + unsigned long tmo_ms); 98 106 #endif