xref: /linux/drivers/w1/masters/amd_axi_w1.c (revision 94901b7a74d82bfd30420f1d9d00898278fdc8bf)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * amd_axi_w1 - AMD 1Wire programmable logic bus host driver
4  *
5  * Copyright (C) 2022-2023 Advanced Micro Devices, Inc. All Rights Reserved.
6  */
7 
8 #include <linux/atomic.h>
9 #include <linux/bitfield.h>
10 #include <linux/clk.h>
11 #include <linux/interrupt.h>
12 #include <linux/io.h>
13 #include <linux/jiffies.h>
14 #include <linux/kernel.h>
15 #include <linux/mod_devicetable.h>
16 #include <linux/module.h>
17 #include <linux/platform_device.h>
18 #include <linux/types.h>
19 #include <linux/wait.h>
20 
21 #include <linux/w1.h>
22 
23 /* 1-wire AMD IP definition */
24 #define AXIW1_IPID	0x10ee4453
25 /* Registers offset */
26 #define AXIW1_INST_REG	0x0
27 #define AXIW1_CTRL_REG	0x4
28 #define AXIW1_IRQE_REG	0x8
29 #define AXIW1_STAT_REG	0xC
30 #define AXIW1_DATA_REG	0x10
31 #define AXIW1_IPVER_REG	0x18
32 #define AXIW1_IPID_REG	0x1C
33 /* Instructions */
34 #define AXIW1_INITPRES	0x0800
35 #define AXIW1_READBIT	0x0C00
36 #define AXIW1_WRITEBIT	0x0E00
37 #define AXIW1_READBYTE	0x0D00
38 #define AXIW1_WRITEBYTE	0x0F00
39 /* Status flag masks */
40 #define AXIW1_DONE	BIT(0)
41 #define AXIW1_READY	BIT(4)
42 #define AXIW1_PRESENCE	BIT(31)
43 #define AXIW1_MAJORVER_MASK	GENMASK(23, 8)
44 #define AXIW1_MINORVER_MASK	GENMASK(7, 0)
45 /* Control flag */
46 #define AXIW1_GO	BIT(0)
47 #define AXI_CLEAR	0
48 #define AXI_RESET	BIT(31)
49 #define AXIW1_READDATA	BIT(0)
50 /* Interrupt Enable */
51 #define AXIW1_READY_IRQ_EN	BIT(4)
52 #define AXIW1_DONE_IRQ_EN	BIT(0)
53 
54 #define AXIW1_TIMEOUT	msecs_to_jiffies(100)
55 
56 #define DRIVER_NAME	"amd_axi_w1"
57 
58 struct amd_axi_w1_local {
59 	struct device *dev;
60 	void __iomem *base_addr;
61 	int irq;
62 	atomic_t flag;			/* Set on IRQ, cleared once serviced */
63 	wait_queue_head_t wait_queue;
64 	struct w1_bus_master bus_host;
65 };
66 
67 /**
68  * amd_axi_w1_wait_irq_interruptible_timeout() - Wait for IRQ with timeout.
69  *
70  * @amd_axi_w1_local:	Pointer to device structure
71  * @IRQ:		IRQ channel to wait on
72  *
73  * Return:		%0 - OK, %-EINTR - Interrupted, %-EBUSY - Timed out
74  */
75 static int amd_axi_w1_wait_irq_interruptible_timeout(struct amd_axi_w1_local *amd_axi_w1_local,
76 						     u32 IRQ)
77 {
78 	int ret;
79 
80 	/* Enable the IRQ requested and wait for flag to indicate it's been triggered */
81 	iowrite32(IRQ, amd_axi_w1_local->base_addr + AXIW1_IRQE_REG);
82 	ret = wait_event_interruptible_timeout(amd_axi_w1_local->wait_queue,
83 					       atomic_read(&amd_axi_w1_local->flag) != 0,
84 					       AXIW1_TIMEOUT);
85 	if (ret < 0) {
86 		dev_err(amd_axi_w1_local->dev, "Wait IRQ Interrupted\n");
87 		return -EINTR;
88 	}
89 
90 	if (!ret) {
91 		dev_err(amd_axi_w1_local->dev, "Wait IRQ Timeout\n");
92 		return -EBUSY;
93 	}
94 
95 	atomic_set(&amd_axi_w1_local->flag, 0);
96 	return 0;
97 }
98 
99 /**
100  * amd_axi_w1_touch_bit() - Performs the touch-bit function - write a 0 or 1 and reads the level.
101  *
102  * @data:	Pointer to device structure
103  * @bit:	The level to write
104  *
105  * Return:	The level read
106  */
107 static u8 amd_axi_w1_touch_bit(void *data, u8 bit)
108 {
109 	struct amd_axi_w1_local *amd_axi_w1_local = data;
110 	u8 val = 0;
111 	int rc;
112 
113 	/* Wait for READY signal to be 1 to ensure 1-wire IP is ready */
114 	while ((ioread32(amd_axi_w1_local->base_addr + AXIW1_STAT_REG) & AXIW1_READY) == 0) {
115 		rc = amd_axi_w1_wait_irq_interruptible_timeout(amd_axi_w1_local,
116 							       AXIW1_READY_IRQ_EN);
117 		if (rc < 0)
118 			return 1; /* Callee doesn't test for error. Return inactive bus state */
119 	}
120 
121 	if (bit)
122 		/* Read. Write read Bit command in register 0 */
123 		iowrite32(AXIW1_READBIT, amd_axi_w1_local->base_addr + AXIW1_INST_REG);
124 	else
125 		/* Write. Write tx Bit command in instruction register with bit to transmit */
126 		iowrite32(AXIW1_WRITEBIT + (bit & 0x01),
127 			  amd_axi_w1_local->base_addr + AXIW1_INST_REG);
128 
129 	/* Write Go signal and clear control reset signal in control register */
130 	iowrite32(AXIW1_GO, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
131 
132 	/* Wait for done signal to be 1 */
133 	while ((ioread32(amd_axi_w1_local->base_addr + AXIW1_STAT_REG) & AXIW1_DONE) != 1) {
134 		rc = amd_axi_w1_wait_irq_interruptible_timeout(amd_axi_w1_local, AXIW1_DONE_IRQ_EN);
135 		if (rc < 0)
136 			return 1; /* Callee doesn't test for error. Return inactive bus state */
137 	}
138 
139 	/* If read, Retrieve data from register */
140 	if (bit)
141 		val = (u8)(ioread32(amd_axi_w1_local->base_addr + AXIW1_DATA_REG) & AXIW1_READDATA);
142 
143 	/* Clear Go signal in register 1 */
144 	iowrite32(AXI_CLEAR, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
145 
146 	return val;
147 }
148 
149 /**
150  * amd_axi_w1_read_byte - Performs the read byte function.
151  *
152  * @data:	Pointer to device structure
153  * Return:	The value read
154  */
155 static u8 amd_axi_w1_read_byte(void *data)
156 {
157 	struct amd_axi_w1_local *amd_axi_w1_local = data;
158 	u8 val = 0;
159 	int rc;
160 
161 	/* Wait for READY signal to be 1 to ensure 1-wire IP is ready */
162 	while ((ioread32(amd_axi_w1_local->base_addr + AXIW1_STAT_REG) & AXIW1_READY) == 0) {
163 		rc = amd_axi_w1_wait_irq_interruptible_timeout(amd_axi_w1_local,
164 							       AXIW1_READY_IRQ_EN);
165 		if (rc < 0)
166 			return 0xFF; /* Return inactive bus state */
167 	}
168 
169 	/* Write read Byte command in instruction register*/
170 	iowrite32(AXIW1_READBYTE, amd_axi_w1_local->base_addr + AXIW1_INST_REG);
171 
172 	/* Write Go signal and clear control reset signal in control register */
173 	iowrite32(AXIW1_GO, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
174 
175 	/* Wait for done signal to be 1 */
176 	while ((ioread32(amd_axi_w1_local->base_addr + AXIW1_STAT_REG) & AXIW1_DONE) != 1) {
177 		rc = amd_axi_w1_wait_irq_interruptible_timeout(amd_axi_w1_local, AXIW1_DONE_IRQ_EN);
178 		if (rc < 0)
179 			return 0xFF; /* Return inactive bus state */
180 	}
181 
182 	/* Retrieve LSB bit in data register to get RX byte */
183 	val = (u8)(ioread32(amd_axi_w1_local->base_addr + AXIW1_DATA_REG) & 0x000000FF);
184 
185 	/* Clear Go signal in control register */
186 	iowrite32(AXI_CLEAR, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
187 
188 	return val;
189 }
190 
191 /**
192  * amd_axi_w1_write_byte - Performs the write byte function.
193  *
194  * @data:	The ds2482 channel pointer
195  * @val:	The value to write
196  */
197 static void amd_axi_w1_write_byte(void *data, u8 val)
198 {
199 	struct amd_axi_w1_local *amd_axi_w1_local = data;
200 	int rc;
201 
202 	/* Wait for READY signal to be 1 to ensure 1-wire IP is ready */
203 	while ((ioread32(amd_axi_w1_local->base_addr + AXIW1_STAT_REG) & AXIW1_READY) == 0) {
204 		rc = amd_axi_w1_wait_irq_interruptible_timeout(amd_axi_w1_local,
205 							       AXIW1_READY_IRQ_EN);
206 		if (rc < 0)
207 			return;
208 	}
209 
210 	/* Write tx Byte command in instruction register with bit to transmit */
211 	iowrite32(AXIW1_WRITEBYTE + val, amd_axi_w1_local->base_addr + AXIW1_INST_REG);
212 
213 	/* Write Go signal and clear control reset signal in register 1 */
214 	iowrite32(AXIW1_GO, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
215 
216 	/* Wait for done signal to be 1 */
217 	while ((ioread32(amd_axi_w1_local->base_addr + AXIW1_STAT_REG) & AXIW1_DONE) != 1) {
218 		rc = amd_axi_w1_wait_irq_interruptible_timeout(amd_axi_w1_local,
219 							       AXIW1_DONE_IRQ_EN);
220 		if (rc < 0)
221 			return;
222 	}
223 
224 	/* Clear Go signal in control register */
225 	iowrite32(AXI_CLEAR, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
226 }
227 
228 /**
229  * amd_axi_w1_reset_bus() - Issues a reset bus sequence.
230  *
231  * @data:	the bus host data struct
232  * Return:	0=Device present, 1=No device present or error
233  */
234 static u8 amd_axi_w1_reset_bus(void *data)
235 {
236 	struct amd_axi_w1_local *amd_axi_w1_local = data;
237 	u8 val = 0;
238 	int rc;
239 
240 	/* Reset 1-wire Axi IP */
241 	iowrite32(AXI_RESET, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
242 
243 	/* Wait for READY signal to be 1 to ensure 1-wire IP is ready */
244 	while ((ioread32(amd_axi_w1_local->base_addr + AXIW1_STAT_REG) & AXIW1_READY) == 0) {
245 		rc = amd_axi_w1_wait_irq_interruptible_timeout(amd_axi_w1_local,
246 							       AXIW1_READY_IRQ_EN);
247 		if (rc < 0)
248 			return 1; /* Something went wrong with the hardware */
249 	}
250 	/* Write Initialization command in instruction register */
251 	iowrite32(AXIW1_INITPRES, amd_axi_w1_local->base_addr + AXIW1_INST_REG);
252 
253 	/* Write Go signal and clear control reset signal in register 1 */
254 	iowrite32(AXIW1_GO, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
255 
256 	/* Wait for done signal to be 1 */
257 	while ((ioread32(amd_axi_w1_local->base_addr + AXIW1_STAT_REG) & AXIW1_DONE) != 1) {
258 		rc = amd_axi_w1_wait_irq_interruptible_timeout(amd_axi_w1_local, AXIW1_DONE_IRQ_EN);
259 		if (rc < 0)
260 			return 1; /* Something went wrong with the hardware */
261 	}
262 	/* Retrieve MSB bit in status register to get failure bit */
263 	if ((ioread32(amd_axi_w1_local->base_addr + AXIW1_STAT_REG) & AXIW1_PRESENCE) != 0)
264 		val = 1;
265 
266 	/* Clear Go signal in control register */
267 	iowrite32(AXI_CLEAR, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
268 
269 	return val;
270 }
271 
272 /* Reset the 1-wire AXI IP. Put the IP in reset state and clear registers */
273 static void amd_axi_w1_reset(struct amd_axi_w1_local *amd_axi_w1_local)
274 {
275 	iowrite32(AXI_RESET, amd_axi_w1_local->base_addr + AXIW1_CTRL_REG);
276 	iowrite32(AXI_CLEAR, amd_axi_w1_local->base_addr + AXIW1_INST_REG);
277 	iowrite32(AXI_CLEAR, amd_axi_w1_local->base_addr + AXIW1_IRQE_REG);
278 	iowrite32(AXI_CLEAR, amd_axi_w1_local->base_addr + AXIW1_STAT_REG);
279 	iowrite32(AXI_CLEAR, amd_axi_w1_local->base_addr + AXIW1_DATA_REG);
280 }
281 
282 static irqreturn_t amd_axi_w1_irq(int irq, void *lp)
283 {
284 	struct amd_axi_w1_local *amd_axi_w1_local = lp;
285 
286 	/* Reset interrupt trigger */
287 	iowrite32(AXI_CLEAR, amd_axi_w1_local->base_addr + AXIW1_IRQE_REG);
288 
289 	atomic_set(&amd_axi_w1_local->flag, 1);
290 	wake_up_interruptible(&amd_axi_w1_local->wait_queue);
291 
292 	return IRQ_HANDLED;
293 }
294 
295 static int amd_axi_w1_probe(struct platform_device *pdev)
296 {
297 	struct device *dev = &pdev->dev;
298 	struct amd_axi_w1_local *lp;
299 	struct clk *clk;
300 	u32 ver_major, ver_minor;
301 	int val, rc = 0;
302 
303 	lp = devm_kzalloc(dev, sizeof(*lp), GFP_KERNEL);
304 	if (!lp)
305 		return -ENOMEM;
306 
307 	lp->dev = dev;
308 	lp->base_addr = devm_platform_ioremap_resource(pdev, 0);
309 	if (IS_ERR(lp->base_addr))
310 		return PTR_ERR(lp->base_addr);
311 
312 	lp->irq = platform_get_irq(pdev, 0);
313 	if (lp->irq < 0)
314 		return lp->irq;
315 
316 	rc = devm_request_irq(dev, lp->irq, &amd_axi_w1_irq, IRQF_TRIGGER_HIGH, DRIVER_NAME, lp);
317 	if (rc)
318 		return rc;
319 
320 	/* Initialize wait queue and flag */
321 	init_waitqueue_head(&lp->wait_queue);
322 
323 	clk = devm_clk_get_enabled(dev, NULL);
324 	if (IS_ERR(clk))
325 		return PTR_ERR(clk);
326 
327 	/* Verify IP presence in HW */
328 	if (ioread32(lp->base_addr + AXIW1_IPID_REG) != AXIW1_IPID) {
329 		dev_err(dev, "AMD 1-wire IP not detected in hardware\n");
330 		return -ENODEV;
331 	}
332 
333 	/*
334 	 * Allow for future driver expansion supporting new hardware features
335 	 * This driver currently only supports hardware 1.x, but include logic
336 	 * to detect if a potentially incompatible future version is used
337 	 * by reading major version ID. It is highly undesirable for new IP versions
338 	 * to break the API, but this code will at least allow for graceful failure
339 	 * should that happen. Future new features can be enabled by hardware
340 	 * incrementing the minor version and augmenting the driver to detect capability
341 	 * using the minor version number
342 	 */
343 	val = ioread32(lp->base_addr + AXIW1_IPVER_REG);
344 	ver_major = FIELD_GET(AXIW1_MAJORVER_MASK, val);
345 	ver_minor = FIELD_GET(AXIW1_MINORVER_MASK, val);
346 
347 	if (ver_major != 1) {
348 		dev_err(dev, "AMD AXI W1 host version %u.%u is not supported by this driver",
349 			ver_major, ver_minor);
350 		return -ENODEV;
351 	}
352 
353 	lp->bus_host.data = lp;
354 	lp->bus_host.touch_bit = amd_axi_w1_touch_bit;
355 	lp->bus_host.read_byte = amd_axi_w1_read_byte;
356 	lp->bus_host.write_byte = amd_axi_w1_write_byte;
357 	lp->bus_host.reset_bus = amd_axi_w1_reset_bus;
358 
359 	amd_axi_w1_reset(lp);
360 
361 	platform_set_drvdata(pdev, lp);
362 	rc = w1_add_master_device(&lp->bus_host);
363 	if (rc) {
364 		dev_err(dev, "Could not add host device\n");
365 		return rc;
366 	}
367 
368 	return 0;
369 }
370 
371 static void amd_axi_w1_remove(struct platform_device *pdev)
372 {
373 	struct amd_axi_w1_local *lp = platform_get_drvdata(pdev);
374 
375 	w1_remove_master_device(&lp->bus_host);
376 }
377 
378 static const struct of_device_id amd_axi_w1_of_match[] = {
379 	{ .compatible = "amd,axi-1wire-host" },
380 	{ /* end of list */ },
381 };
382 MODULE_DEVICE_TABLE(of, amd_axi_w1_of_match);
383 
384 static struct platform_driver amd_axi_w1_driver = {
385 	.probe = amd_axi_w1_probe,
386 	.remove = amd_axi_w1_remove,
387 	.driver = {
388 		.name = DRIVER_NAME,
389 		.of_match_table = amd_axi_w1_of_match,
390 	},
391 };
392 module_platform_driver(amd_axi_w1_driver);
393 
394 MODULE_LICENSE("GPL");
395 MODULE_AUTHOR("Kris Chaplin <kris.chaplin@amd.com>");
396 MODULE_DESCRIPTION("Driver for AMD AXI 1 Wire IP core");
397