| 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
| 2 | /* |
| 3 | * Copyright (C) 2022 Renesas Electronics Corporation |
| 4 | */ |
| 5 | #ifndef __MFD_RZ_MTU3_H__ |
| 6 | #define __MFD_RZ_MTU3_H__ |
| 7 | |
| 8 | #include <linux/clk.h> |
| 9 | #include <linux/device.h> |
| 10 | #include <linux/mutex.h> |
| 11 | |
| 12 | /* 8-bit shared register offsets macros */ |
| 13 | #define RZ_MTU3_TSTRA 0x080 /* Timer start register A */ |
| 14 | #define RZ_MTU3_TSTRB 0x880 /* Timer start register B */ |
| 15 | |
| 16 | /* 16-bit shared register offset macros */ |
| 17 | #define RZ_MTU3_TDDRA 0x016 /* Timer dead time data register A */ |
| 18 | #define RZ_MTU3_TDDRB 0x816 /* Timer dead time data register B */ |
| 19 | #define RZ_MTU3_TCDRA 0x014 /* Timer cycle data register A */ |
| 20 | #define RZ_MTU3_TCDRB 0x814 /* Timer cycle data register B */ |
| 21 | #define RZ_MTU3_TCBRA 0x022 /* Timer cycle buffer register A */ |
| 22 | #define RZ_MTU3_TCBRB 0x822 /* Timer cycle buffer register B */ |
| 23 | #define RZ_MTU3_TCNTSA 0x020 /* Timer subcounter A */ |
| 24 | #define RZ_MTU3_TCNTSB 0x820 /* Timer subcounter B */ |
| 25 | |
| 26 | /* |
| 27 | * MTU5 contains 3 timer counter registers and is totaly different |
| 28 | * from other channels, so we must separate its offset |
| 29 | */ |
| 30 | |
| 31 | /* 8-bit register offset macros of MTU3 channels except MTU5 */ |
| 32 | #define RZ_MTU3_TIER 0 /* Timer interrupt register */ |
| 33 | #define RZ_MTU3_NFCR 1 /* Noise filter control register */ |
| 34 | #define RZ_MTU3_TSR 2 /* Timer status register */ |
| 35 | #define RZ_MTU3_TCR 3 /* Timer control register */ |
| 36 | #define RZ_MTU3_TCR2 4 /* Timer control register 2 */ |
| 37 | |
| 38 | /* Timer mode register 1 */ |
| 39 | #define RZ_MTU3_TMDR1 5 |
| 40 | #define RZ_MTU3_TMDR1_MD GENMASK(3, 0) |
| 41 | #define RZ_MTU3_TMDR1_MD_NORMAL FIELD_PREP(RZ_MTU3_TMDR1_MD, 0) |
| 42 | #define RZ_MTU3_TMDR1_MD_PWMMODE1 FIELD_PREP(RZ_MTU3_TMDR1_MD, 2) |
| 43 | |
| 44 | #define RZ_MTU3_TIOR 6 /* Timer I/O control register */ |
| 45 | #define RZ_MTU3_TIORH 6 /* Timer I/O control register H */ |
| 46 | #define RZ_MTU3_TIORL 7 /* Timer I/O control register L */ |
| 47 | /* Only MTU3/4/6/7 have TBTM registers */ |
| 48 | #define RZ_MTU3_TBTM 8 /* Timer buffer operation transfer mode register */ |
| 49 | |
| 50 | /* 8-bit MTU5 register offset macros */ |
| 51 | #define RZ_MTU3_TSTR 2 /* MTU5 Timer start register */ |
| 52 | #define RZ_MTU3_TCNTCMPCLR 3 /* MTU5 Timer compare match clear register */ |
| 53 | #define RZ_MTU3_TCRU 4 /* Timer control register U */ |
| 54 | #define RZ_MTU3_TCR2U 5 /* Timer control register 2U */ |
| 55 | #define RZ_MTU3_TIORU 6 /* Timer I/O control register U */ |
| 56 | #define RZ_MTU3_TCRV 7 /* Timer control register V */ |
| 57 | #define RZ_MTU3_TCR2V 8 /* Timer control register 2V */ |
| 58 | #define RZ_MTU3_TIORV 9 /* Timer I/O control register V */ |
| 59 | #define RZ_MTU3_TCRW 10 /* Timer control register W */ |
| 60 | #define RZ_MTU3_TCR2W 11 /* Timer control register 2W */ |
| 61 | #define RZ_MTU3_TIORW 12 /* Timer I/O control register W */ |
| 62 | |
| 63 | /* 16-bit register offset macros of MTU3 channels except MTU5 */ |
| 64 | #define RZ_MTU3_TCNT 0 /* Timer counter */ |
| 65 | #define RZ_MTU3_TGRA 1 /* Timer general register A */ |
| 66 | #define RZ_MTU3_TGRB 2 /* Timer general register B */ |
| 67 | #define RZ_MTU3_TGRC 3 /* Timer general register C */ |
| 68 | #define RZ_MTU3_TGRD 4 /* Timer general register D */ |
| 69 | #define RZ_MTU3_TGRE 5 /* Timer general register E */ |
| 70 | #define RZ_MTU3_TGRF 6 /* Timer general register F */ |
| 71 | /* Timer A/D converter start request registers */ |
| 72 | #define RZ_MTU3_TADCR 7 /* control register */ |
| 73 | #define RZ_MTU3_TADCORA 8 /* cycle set register A */ |
| 74 | #define RZ_MTU3_TADCORB 9 /* cycle set register B */ |
| 75 | #define RZ_MTU3_TADCOBRA 10 /* cycle set buffer register A */ |
| 76 | #define RZ_MTU3_TADCOBRB 11 /* cycle set buffer register B */ |
| 77 | |
| 78 | /* 16-bit MTU5 register offset macros */ |
| 79 | #define RZ_MTU3_TCNTU 0 /* MTU5 Timer counter U */ |
| 80 | #define RZ_MTU3_TGRU 1 /* MTU5 Timer general register U */ |
| 81 | #define RZ_MTU3_TCNTV 2 /* MTU5 Timer counter V */ |
| 82 | #define RZ_MTU3_TGRV 3 /* MTU5 Timer general register V */ |
| 83 | #define RZ_MTU3_TCNTW 4 /* MTU5 Timer counter W */ |
| 84 | #define RZ_MTU3_TGRW 5 /* MTU5 Timer general register W */ |
| 85 | |
| 86 | /* 32-bit register offset */ |
| 87 | #define RZ_MTU3_TCNTLW 0 /* Timer longword counter */ |
| 88 | #define RZ_MTU3_TGRALW 1 /* Timer longword general register A */ |
| 89 | #define RZ_MTU3_TGRBLW 2 /* Timer longowrd general register B */ |
| 90 | |
| 91 | #define RZ_MTU3_TMDR3 0x191 /* MTU1 Timer Mode Register 3 */ |
| 92 | |
| 93 | /* Macros for setting registers */ |
| 94 | #define RZ_MTU3_TCR_CCLR GENMASK(7, 5) |
| 95 | #define RZ_MTU3_TCR_CKEG GENMASK(4, 3) |
| 96 | #define RZ_MTU3_TCR_TPCS GENMASK(2, 0) |
| 97 | #define RZ_MTU3_TCR_CCLR_TGRA BIT(5) |
| 98 | #define RZ_MTU3_TCR_CCLR_TGRC FIELD_PREP(RZ_MTU3_TCR_CCLR, 5) |
| 99 | #define RZ_MTU3_TCR_CKEG_RISING FIELD_PREP(RZ_MTU3_TCR_CKEG, 0) |
| 100 | |
| 101 | #define RZ_MTU3_TIOR_IOB GENMASK(7, 4) |
| 102 | #define RZ_MTU3_TIOR_IOA GENMASK(3, 0) |
| 103 | #define RZ_MTU3_TIOR_OC_RETAIN 0 |
| 104 | #define RZ_MTU3_TIOR_OC_INIT_OUT_LO_HI_OUT 2 |
| 105 | #define RZ_MTU3_TIOR_OC_INIT_OUT_HI_TOGGLE_OUT 7 |
| 106 | |
| 107 | #define RZ_MTU3_TIOR_OC_IOA_H_COMP_MATCH \ |
| 108 | FIELD_PREP(RZ_MTU3_TIOR_IOA, RZ_MTU3_TIOR_OC_INIT_OUT_LO_HI_OUT) |
| 109 | #define RZ_MTU3_TIOR_OC_IOB_TOGGLE \ |
| 110 | FIELD_PREP(RZ_MTU3_TIOR_IOB, RZ_MTU3_TIOR_OC_INIT_OUT_HI_TOGGLE_OUT) |
| 111 | |
| 112 | enum rz_mtu3_channels { |
| 113 | RZ_MTU3_CHAN_0, |
| 114 | RZ_MTU3_CHAN_1, |
| 115 | RZ_MTU3_CHAN_2, |
| 116 | RZ_MTU3_CHAN_3, |
| 117 | RZ_MTU3_CHAN_4, |
| 118 | RZ_MTU3_CHAN_5, |
| 119 | RZ_MTU3_CHAN_6, |
| 120 | RZ_MTU3_CHAN_7, |
| 121 | RZ_MTU3_CHAN_8, |
| 122 | RZ_MTU_NUM_CHANNELS |
| 123 | }; |
| 124 | |
| 125 | /** |
| 126 | * struct rz_mtu3_channel - MTU3 channel private data |
| 127 | * |
| 128 | * @dev: device handle |
| 129 | * @channel_number: channel number |
| 130 | * @lock: Lock to protect channel state |
| 131 | * @is_busy: channel state |
| 132 | */ |
| 133 | struct rz_mtu3_channel { |
| 134 | struct device *dev; |
| 135 | unsigned int channel_number; |
| 136 | struct mutex lock; |
| 137 | bool is_busy; |
| 138 | }; |
| 139 | |
| 140 | /** |
| 141 | * struct rz_mtu3 - MTU3 core private data |
| 142 | * |
| 143 | * @clk: MTU3 module clock |
| 144 | * @rz_mtu3_channel: HW channels |
| 145 | * @priv_data: MTU3 core driver private data |
| 146 | */ |
| 147 | struct rz_mtu3 { |
| 148 | struct clk *clk; |
| 149 | struct rz_mtu3_channel channels[RZ_MTU_NUM_CHANNELS]; |
| 150 | |
| 151 | void *priv_data; |
| 152 | }; |
| 153 | |
| 154 | static inline bool rz_mtu3_request_channel(struct rz_mtu3_channel *ch) |
| 155 | { |
| 156 | mutex_lock(&ch->lock); |
| 157 | if (ch->is_busy) { |
| 158 | mutex_unlock(lock: &ch->lock); |
| 159 | return false; |
| 160 | } |
| 161 | |
| 162 | ch->is_busy = true; |
| 163 | mutex_unlock(lock: &ch->lock); |
| 164 | |
| 165 | return true; |
| 166 | } |
| 167 | |
| 168 | static inline void rz_mtu3_release_channel(struct rz_mtu3_channel *ch) |
| 169 | { |
| 170 | mutex_lock(&ch->lock); |
| 171 | ch->is_busy = false; |
| 172 | mutex_unlock(lock: &ch->lock); |
| 173 | } |
| 174 | |
| 175 | bool rz_mtu3_is_enabled(struct rz_mtu3_channel *ch); |
| 176 | void rz_mtu3_disable(struct rz_mtu3_channel *ch); |
| 177 | int rz_mtu3_enable(struct rz_mtu3_channel *ch); |
| 178 | |
| 179 | u8 rz_mtu3_8bit_ch_read(struct rz_mtu3_channel *ch, u16 off); |
| 180 | u16 rz_mtu3_16bit_ch_read(struct rz_mtu3_channel *ch, u16 off); |
| 181 | u32 rz_mtu3_32bit_ch_read(struct rz_mtu3_channel *ch, u16 off); |
| 182 | u16 rz_mtu3_shared_reg_read(struct rz_mtu3_channel *ch, u16 off); |
| 183 | |
| 184 | void rz_mtu3_8bit_ch_write(struct rz_mtu3_channel *ch, u16 off, u8 val); |
| 185 | void rz_mtu3_16bit_ch_write(struct rz_mtu3_channel *ch, u16 off, u16 val); |
| 186 | void rz_mtu3_32bit_ch_write(struct rz_mtu3_channel *ch, u16 off, u32 val); |
| 187 | void rz_mtu3_shared_reg_write(struct rz_mtu3_channel *ch, u16 off, u16 val); |
| 188 | void rz_mtu3_shared_reg_update_bit(struct rz_mtu3_channel *ch, u16 off, |
| 189 | u16 pos, u8 val); |
| 190 | |
| 191 | #endif /* __MFD_RZ_MTU3_H__ */ |
| 192 | |