~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/linux/mfd/rz-mtu3.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  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(&ch->lock);
159                 return false;
160         }
161 
162         ch->is_busy = true;
163         mutex_unlock(&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(&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 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php