xref: /linux/drivers/hwtracing/coresight/coresight-catu.c (revision c532de5a67a70f8533d495f8f2aaa9a0491c3ad0)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Copyright (C) 2018 Arm Limited. All rights reserved.
4  *
5  * Coresight Address Translation Unit support
6  *
7  * Author: Suzuki K Poulose <suzuki.poulose@arm.com>
8  */
9 
10 #include <linux/acpi.h>
11 #include <linux/amba/bus.h>
12 #include <linux/device.h>
13 #include <linux/dma-mapping.h>
14 #include <linux/io.h>
15 #include <linux/kernel.h>
16 #include <linux/platform_device.h>
17 #include <linux/slab.h>
18 
19 #include "coresight-catu.h"
20 #include "coresight-priv.h"
21 #include "coresight-tmc.h"
22 
23 #define csdev_to_catu_drvdata(csdev)	\
24 	dev_get_drvdata(csdev->dev.parent)
25 
26 /* Verbose output for CATU table contents */
27 #ifdef CATU_DEBUG
28 #define catu_dbg(x, ...) dev_dbg(x, __VA_ARGS__)
29 #else
30 #define catu_dbg(x, ...) do {} while (0)
31 #endif
32 
33 DEFINE_CORESIGHT_DEVLIST(catu_devs, "catu");
34 
35 struct catu_etr_buf {
36 	struct tmc_sg_table *catu_table;
37 	dma_addr_t sladdr;
38 };
39 
40 /*
41  * CATU uses a page size of 4KB for page tables as well as data pages.
42  * Each 64bit entry in the table has the following format.
43  *
44  *	63			12	1  0
45  *	------------------------------------
46  *	|	 Address [63-12] | SBZ	| V|
47  *	------------------------------------
48  *
49  * Where bit[0] V indicates if the address is valid or not.
50  * Each 4K table pages have upto 256 data page pointers, taking upto 2K
51  * size. There are two Link pointers, pointing to the previous and next
52  * table pages respectively at the end of the 4K page. (i.e, entry 510
53  * and 511).
54  *  E.g, a table of two pages could look like :
55  *
56  *                 Table Page 0               Table Page 1
57  * SLADDR ===> x------------------x  x--> x-----------------x
58  * INADDR    ->|  Page 0      | V |  |    | Page 256    | V | <- INADDR+1M
59  *             |------------------|  |    |-----------------|
60  * INADDR+4K ->|  Page 1      | V |  |    |                 |
61  *             |------------------|  |    |-----------------|
62  *             |  Page 2      | V |  |    |                 |
63  *             |------------------|  |    |-----------------|
64  *             |   ...        | V |  |    |    ...          |
65  *             |------------------|  |    |-----------------|
66  * INADDR+1020K|  Page 255    | V |  |    |   Page 511  | V |
67  * SLADDR+2K==>|------------------|  |    |-----------------|
68  *             |  UNUSED      |   |  |    |                 |
69  *             |------------------|  |    |                 |
70  *             |  UNUSED      |   |  |    |                 |
71  *             |------------------|  |    |                 |
72  *             |    ...       |   |  |    |                 |
73  *             |------------------|  |    |-----------------|
74  *             |   IGNORED    | 0 |  |    | Table Page 0| 1 |
75  *             |------------------|  |    |-----------------|
76  *             |  Table Page 1| 1 |--x    | IGNORED     | 0 |
77  *             x------------------x       x-----------------x
78  * SLADDR+4K==>
79  *
80  * The base input address (used by the ETR, programmed in INADDR_{LO,HI})
81  * must be aligned to 1MB (the size addressable by a single page table).
82  * The CATU maps INADDR{LO:HI} to the first page in the table pointed
83  * to by SLADDR{LO:HI} and so on.
84  *
85  */
86 typedef u64 cate_t;
87 
88 #define CATU_PAGE_SHIFT		12
89 #define CATU_PAGE_SIZE		(1UL << CATU_PAGE_SHIFT)
90 #define CATU_PAGES_PER_SYSPAGE	(PAGE_SIZE / CATU_PAGE_SIZE)
91 
92 /* Page pointers are only allocated in the first 2K half */
93 #define CATU_PTRS_PER_PAGE	((CATU_PAGE_SIZE >> 1) / sizeof(cate_t))
94 #define CATU_PTRS_PER_SYSPAGE	(CATU_PAGES_PER_SYSPAGE * CATU_PTRS_PER_PAGE)
95 #define CATU_LINK_PREV		((CATU_PAGE_SIZE / sizeof(cate_t)) - 2)
96 #define CATU_LINK_NEXT		((CATU_PAGE_SIZE / sizeof(cate_t)) - 1)
97 
98 #define CATU_ADDR_SHIFT		12
99 #define CATU_ADDR_MASK		~(((cate_t)1 << CATU_ADDR_SHIFT) - 1)
100 #define CATU_ENTRY_VALID	((cate_t)0x1)
101 #define CATU_VALID_ENTRY(addr) \
102 	(((cate_t)(addr) & CATU_ADDR_MASK) | CATU_ENTRY_VALID)
103 #define CATU_ENTRY_ADDR(entry)	((cate_t)(entry) & ~((cate_t)CATU_ENTRY_VALID))
104 
105 /* CATU expects the INADDR to be aligned to 1M. */
106 #define CATU_DEFAULT_INADDR	(1ULL << 20)
107 
108 /*
109  * catu_get_table : Retrieve the table pointers for the given @offset
110  * within the buffer. The buffer is wrapped around to a valid offset.
111  *
112  * Returns : The CPU virtual address for the beginning of the table
113  * containing the data page pointer for @offset. If @daddrp is not NULL,
114  * @daddrp points the DMA address of the beginning of the table.
115  */
116 static inline cate_t *catu_get_table(struct tmc_sg_table *catu_table,
117 				     unsigned long offset,
118 				     dma_addr_t *daddrp)
119 {
120 	unsigned long buf_size = tmc_sg_table_buf_size(catu_table);
121 	unsigned int table_nr, pg_idx, pg_offset;
122 	struct tmc_pages *table_pages = &catu_table->table_pages;
123 	void *ptr;
124 
125 	/* Make sure offset is within the range */
126 	offset %= buf_size;
127 
128 	/*
129 	 * Each table can address 1MB and a single kernel page can
130 	 * contain "CATU_PAGES_PER_SYSPAGE" CATU tables.
131 	 */
132 	table_nr = offset >> 20;
133 	/* Find the table page where the table_nr lies in */
134 	pg_idx = table_nr / CATU_PAGES_PER_SYSPAGE;
135 	pg_offset = (table_nr % CATU_PAGES_PER_SYSPAGE) * CATU_PAGE_SIZE;
136 	if (daddrp)
137 		*daddrp = table_pages->daddrs[pg_idx] + pg_offset;
138 	ptr = page_address(table_pages->pages[pg_idx]);
139 	return (cate_t *)((unsigned long)ptr + pg_offset);
140 }
141 
142 #ifdef CATU_DEBUG
143 static void catu_dump_table(struct tmc_sg_table *catu_table)
144 {
145 	int i;
146 	cate_t *table;
147 	unsigned long table_end, buf_size, offset = 0;
148 
149 	buf_size = tmc_sg_table_buf_size(catu_table);
150 	dev_dbg(catu_table->dev,
151 		"Dump table %p, tdaddr: %llx\n",
152 		catu_table, catu_table->table_daddr);
153 
154 	while (offset < buf_size) {
155 		table_end = offset + SZ_1M < buf_size ?
156 			    offset + SZ_1M : buf_size;
157 		table = catu_get_table(catu_table, offset, NULL);
158 		for (i = 0; offset < table_end; i++, offset += CATU_PAGE_SIZE)
159 			dev_dbg(catu_table->dev, "%d: %llx\n", i, table[i]);
160 		dev_dbg(catu_table->dev, "Prev : %llx, Next: %llx\n",
161 			table[CATU_LINK_PREV], table[CATU_LINK_NEXT]);
162 		dev_dbg(catu_table->dev, "== End of sub-table ===");
163 	}
164 	dev_dbg(catu_table->dev, "== End of Table ===");
165 }
166 
167 #else
168 static inline void catu_dump_table(struct tmc_sg_table *catu_table)
169 {
170 }
171 #endif
172 
173 static inline cate_t catu_make_entry(dma_addr_t addr)
174 {
175 	return addr ? CATU_VALID_ENTRY(addr) : 0;
176 }
177 
178 /*
179  * catu_populate_table : Populate the given CATU table.
180  * The table is always populated as a circular table.
181  * i.e, the "prev" link of the "first" table points to the "last"
182  * table and the "next" link of the "last" table points to the
183  * "first" table. The buffer should be made linear by calling
184  * catu_set_table().
185  */
186 static void
187 catu_populate_table(struct tmc_sg_table *catu_table)
188 {
189 	int i;
190 	int sys_pidx;	/* Index to current system data page */
191 	int catu_pidx;	/* Index of CATU page within the system data page */
192 	unsigned long offset, buf_size, table_end;
193 	dma_addr_t data_daddr;
194 	dma_addr_t prev_taddr, next_taddr, cur_taddr;
195 	cate_t *table_ptr, *next_table;
196 
197 	buf_size = tmc_sg_table_buf_size(catu_table);
198 	sys_pidx = catu_pidx = 0;
199 	offset = 0;
200 
201 	table_ptr = catu_get_table(catu_table, 0, &cur_taddr);
202 	prev_taddr = 0;	/* Prev link for the first table */
203 
204 	while (offset < buf_size) {
205 		/*
206 		 * The @offset is always 1M aligned here and we have an
207 		 * empty table @table_ptr to fill. Each table can address
208 		 * upto 1MB data buffer. The last table may have fewer
209 		 * entries if the buffer size is not aligned.
210 		 */
211 		table_end = (offset + SZ_1M) < buf_size ?
212 			    (offset + SZ_1M) : buf_size;
213 		for (i = 0; offset < table_end;
214 		     i++, offset += CATU_PAGE_SIZE) {
215 
216 			data_daddr = catu_table->data_pages.daddrs[sys_pidx] +
217 				     catu_pidx * CATU_PAGE_SIZE;
218 			catu_dbg(catu_table->dev,
219 				"[table %5ld:%03d] 0x%llx\n",
220 				(offset >> 20), i, data_daddr);
221 			table_ptr[i] = catu_make_entry(data_daddr);
222 			/* Move the pointers for data pages */
223 			catu_pidx = (catu_pidx + 1) % CATU_PAGES_PER_SYSPAGE;
224 			if (catu_pidx == 0)
225 				sys_pidx++;
226 		}
227 
228 		/*
229 		 * If we have finished all the valid entries, fill the rest of
230 		 * the table (i.e, last table page) with invalid entries,
231 		 * to fail the lookups.
232 		 */
233 		if (offset == buf_size) {
234 			memset(&table_ptr[i], 0,
235 			       sizeof(cate_t) * (CATU_PTRS_PER_PAGE - i));
236 			next_taddr = 0;
237 		} else {
238 			next_table = catu_get_table(catu_table,
239 						    offset, &next_taddr);
240 		}
241 
242 		table_ptr[CATU_LINK_PREV] = catu_make_entry(prev_taddr);
243 		table_ptr[CATU_LINK_NEXT] = catu_make_entry(next_taddr);
244 
245 		catu_dbg(catu_table->dev,
246 			"[table%5ld]: Cur: 0x%llx Prev: 0x%llx, Next: 0x%llx\n",
247 			(offset >> 20) - 1,  cur_taddr, prev_taddr, next_taddr);
248 
249 		/* Update the prev/next addresses */
250 		if (next_taddr) {
251 			prev_taddr = cur_taddr;
252 			cur_taddr = next_taddr;
253 			table_ptr = next_table;
254 		}
255 	}
256 
257 	/* Sync the table for device */
258 	tmc_sg_table_sync_table(catu_table);
259 }
260 
261 static struct tmc_sg_table *
262 catu_init_sg_table(struct device *catu_dev, int node,
263 		   ssize_t size, void **pages)
264 {
265 	int nr_tpages;
266 	struct tmc_sg_table *catu_table;
267 
268 	/*
269 	 * Each table can address upto 1MB and we can have
270 	 * CATU_PAGES_PER_SYSPAGE tables in a system page.
271 	 */
272 	nr_tpages = DIV_ROUND_UP(size, SZ_1M) / CATU_PAGES_PER_SYSPAGE;
273 	catu_table = tmc_alloc_sg_table(catu_dev, node, nr_tpages,
274 					size >> PAGE_SHIFT, pages);
275 	if (IS_ERR(catu_table))
276 		return catu_table;
277 
278 	catu_populate_table(catu_table);
279 	dev_dbg(catu_dev,
280 		"Setup table %p, size %ldKB, %d table pages\n",
281 		catu_table, (unsigned long)size >> 10,  nr_tpages);
282 	catu_dump_table(catu_table);
283 	return catu_table;
284 }
285 
286 static void catu_free_etr_buf(struct etr_buf *etr_buf)
287 {
288 	struct catu_etr_buf *catu_buf;
289 
290 	if (!etr_buf || etr_buf->mode != ETR_MODE_CATU || !etr_buf->private)
291 		return;
292 
293 	catu_buf = etr_buf->private;
294 	tmc_free_sg_table(catu_buf->catu_table);
295 	kfree(catu_buf);
296 }
297 
298 static ssize_t catu_get_data_etr_buf(struct etr_buf *etr_buf, u64 offset,
299 				     size_t len, char **bufpp)
300 {
301 	struct catu_etr_buf *catu_buf = etr_buf->private;
302 
303 	return tmc_sg_table_get_data(catu_buf->catu_table, offset, len, bufpp);
304 }
305 
306 static void catu_sync_etr_buf(struct etr_buf *etr_buf, u64 rrp, u64 rwp)
307 {
308 	struct catu_etr_buf *catu_buf = etr_buf->private;
309 	struct tmc_sg_table *catu_table = catu_buf->catu_table;
310 	u64 r_offset, w_offset;
311 
312 	/*
313 	 * ETR started off at etr_buf->hwaddr. Convert the RRP/RWP to
314 	 * offsets within the trace buffer.
315 	 */
316 	r_offset = rrp - etr_buf->hwaddr;
317 	w_offset = rwp - etr_buf->hwaddr;
318 
319 	if (!etr_buf->full) {
320 		etr_buf->len = w_offset - r_offset;
321 		if (w_offset < r_offset)
322 			etr_buf->len += etr_buf->size;
323 	} else {
324 		etr_buf->len = etr_buf->size;
325 	}
326 
327 	etr_buf->offset = r_offset;
328 	tmc_sg_table_sync_data_range(catu_table, r_offset, etr_buf->len);
329 }
330 
331 static int catu_alloc_etr_buf(struct tmc_drvdata *tmc_drvdata,
332 			      struct etr_buf *etr_buf, int node, void **pages)
333 {
334 	struct coresight_device *csdev;
335 	struct tmc_sg_table *catu_table;
336 	struct catu_etr_buf *catu_buf;
337 
338 	csdev = tmc_etr_get_catu_device(tmc_drvdata);
339 	if (!csdev)
340 		return -ENODEV;
341 	catu_buf = kzalloc(sizeof(*catu_buf), GFP_KERNEL);
342 	if (!catu_buf)
343 		return -ENOMEM;
344 
345 	catu_table = catu_init_sg_table(&csdev->dev, node,
346 					etr_buf->size, pages);
347 	if (IS_ERR(catu_table)) {
348 		kfree(catu_buf);
349 		return PTR_ERR(catu_table);
350 	}
351 
352 	etr_buf->mode = ETR_MODE_CATU;
353 	etr_buf->private = catu_buf;
354 	etr_buf->hwaddr = CATU_DEFAULT_INADDR;
355 
356 	catu_buf->catu_table = catu_table;
357 	/* Get the table base address */
358 	catu_buf->sladdr = catu_table->table_daddr;
359 
360 	return 0;
361 }
362 
363 static const struct etr_buf_operations etr_catu_buf_ops = {
364 	.alloc = catu_alloc_etr_buf,
365 	.free = catu_free_etr_buf,
366 	.sync = catu_sync_etr_buf,
367 	.get_data = catu_get_data_etr_buf,
368 };
369 
370 static struct attribute *catu_mgmt_attrs[] = {
371 	coresight_simple_reg32(devid, CORESIGHT_DEVID),
372 	coresight_simple_reg32(control, CATU_CONTROL),
373 	coresight_simple_reg32(status, CATU_STATUS),
374 	coresight_simple_reg32(mode, CATU_MODE),
375 	coresight_simple_reg32(axictrl, CATU_AXICTRL),
376 	coresight_simple_reg32(irqen, CATU_IRQEN),
377 	coresight_simple_reg64(sladdr, CATU_SLADDRLO, CATU_SLADDRHI),
378 	coresight_simple_reg64(inaddr, CATU_INADDRLO, CATU_INADDRHI),
379 	NULL,
380 };
381 
382 static const struct attribute_group catu_mgmt_group = {
383 	.attrs = catu_mgmt_attrs,
384 	.name = "mgmt",
385 };
386 
387 static const struct attribute_group *catu_groups[] = {
388 	&catu_mgmt_group,
389 	NULL,
390 };
391 
392 
393 static inline int catu_wait_for_ready(struct catu_drvdata *drvdata)
394 {
395 	struct csdev_access *csa = &drvdata->csdev->access;
396 
397 	return coresight_timeout(csa, CATU_STATUS, CATU_STATUS_READY, 1);
398 }
399 
400 static int catu_enable_hw(struct catu_drvdata *drvdata, enum cs_mode cs_mode,
401 			  void *data)
402 {
403 	int rc;
404 	u32 control, mode;
405 	struct etr_buf *etr_buf = NULL;
406 	struct device *dev = &drvdata->csdev->dev;
407 	struct coresight_device *csdev = drvdata->csdev;
408 	struct coresight_device *etrdev;
409 	union coresight_dev_subtype etr_subtype = {
410 		.sink_subtype = CORESIGHT_DEV_SUBTYPE_SINK_SYSMEM
411 	};
412 
413 	if (catu_wait_for_ready(drvdata))
414 		dev_warn(dev, "Timeout while waiting for READY\n");
415 
416 	control = catu_read_control(drvdata);
417 	if (control & BIT(CATU_CONTROL_ENABLE)) {
418 		dev_warn(dev, "CATU is already enabled\n");
419 		return -EBUSY;
420 	}
421 
422 	rc = coresight_claim_device_unlocked(csdev);
423 	if (rc)
424 		return rc;
425 
426 	etrdev = coresight_find_input_type(
427 		csdev->pdata, CORESIGHT_DEV_TYPE_SINK, etr_subtype);
428 	if (etrdev) {
429 		etr_buf = tmc_etr_get_buffer(etrdev, cs_mode, data);
430 		if (IS_ERR(etr_buf))
431 			return PTR_ERR(etr_buf);
432 	}
433 	control |= BIT(CATU_CONTROL_ENABLE);
434 
435 	if (etr_buf && etr_buf->mode == ETR_MODE_CATU) {
436 		struct catu_etr_buf *catu_buf = etr_buf->private;
437 
438 		mode = CATU_MODE_TRANSLATE;
439 		catu_write_axictrl(drvdata, CATU_OS_AXICTRL);
440 		catu_write_sladdr(drvdata, catu_buf->sladdr);
441 		catu_write_inaddr(drvdata, CATU_DEFAULT_INADDR);
442 	} else {
443 		mode = CATU_MODE_PASS_THROUGH;
444 		catu_write_sladdr(drvdata, 0);
445 		catu_write_inaddr(drvdata, 0);
446 	}
447 
448 	catu_write_irqen(drvdata, 0);
449 	catu_write_mode(drvdata, mode);
450 	catu_write_control(drvdata, control);
451 	dev_dbg(dev, "Enabled in %s mode\n",
452 		(mode == CATU_MODE_PASS_THROUGH) ?
453 		"Pass through" :
454 		"Translate");
455 	return 0;
456 }
457 
458 static int catu_enable(struct coresight_device *csdev, enum cs_mode mode,
459 		       void *data)
460 {
461 	int rc;
462 	struct catu_drvdata *catu_drvdata = csdev_to_catu_drvdata(csdev);
463 
464 	CS_UNLOCK(catu_drvdata->base);
465 	rc = catu_enable_hw(catu_drvdata, mode, data);
466 	CS_LOCK(catu_drvdata->base);
467 	return rc;
468 }
469 
470 static int catu_disable_hw(struct catu_drvdata *drvdata)
471 {
472 	int rc = 0;
473 	struct device *dev = &drvdata->csdev->dev;
474 	struct coresight_device *csdev = drvdata->csdev;
475 
476 	catu_write_control(drvdata, 0);
477 	coresight_disclaim_device_unlocked(csdev);
478 	if (catu_wait_for_ready(drvdata)) {
479 		dev_info(dev, "Timeout while waiting for READY\n");
480 		rc = -EAGAIN;
481 	}
482 
483 	dev_dbg(dev, "Disabled\n");
484 	return rc;
485 }
486 
487 static int catu_disable(struct coresight_device *csdev, void *__unused)
488 {
489 	int rc;
490 	struct catu_drvdata *catu_drvdata = csdev_to_catu_drvdata(csdev);
491 
492 	CS_UNLOCK(catu_drvdata->base);
493 	rc = catu_disable_hw(catu_drvdata);
494 	CS_LOCK(catu_drvdata->base);
495 	return rc;
496 }
497 
498 static const struct coresight_ops_helper catu_helper_ops = {
499 	.enable = catu_enable,
500 	.disable = catu_disable,
501 };
502 
503 static const struct coresight_ops catu_ops = {
504 	.helper_ops = &catu_helper_ops,
505 };
506 
507 static int __catu_probe(struct device *dev, struct resource *res)
508 {
509 	int ret = 0;
510 	u32 dma_mask;
511 	struct catu_drvdata *drvdata = dev_get_drvdata(dev);
512 	struct coresight_desc catu_desc;
513 	struct coresight_platform_data *pdata = NULL;
514 	void __iomem *base;
515 
516 	catu_desc.name = coresight_alloc_device_name(&catu_devs, dev);
517 	if (!catu_desc.name)
518 		return -ENOMEM;
519 
520 	base = devm_ioremap_resource(dev, res);
521 	if (IS_ERR(base)) {
522 		ret = PTR_ERR(base);
523 		goto out;
524 	}
525 
526 	/* Setup dma mask for the device */
527 	dma_mask = readl_relaxed(base + CORESIGHT_DEVID) & 0x3f;
528 	switch (dma_mask) {
529 	case 32:
530 	case 40:
531 	case 44:
532 	case 48:
533 	case 52:
534 	case 56:
535 	case 64:
536 		break;
537 	default:
538 		/* Default to the 40bits as supported by TMC-ETR */
539 		dma_mask = 40;
540 	}
541 	ret = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(dma_mask));
542 	if (ret)
543 		goto out;
544 
545 	pdata = coresight_get_platform_data(dev);
546 	if (IS_ERR(pdata)) {
547 		ret = PTR_ERR(pdata);
548 		goto out;
549 	}
550 	dev->platform_data = pdata;
551 
552 	drvdata->base = base;
553 	catu_desc.access = CSDEV_ACCESS_IOMEM(base);
554 	catu_desc.pdata = pdata;
555 	catu_desc.dev = dev;
556 	catu_desc.groups = catu_groups;
557 	catu_desc.type = CORESIGHT_DEV_TYPE_HELPER;
558 	catu_desc.subtype.helper_subtype = CORESIGHT_DEV_SUBTYPE_HELPER_CATU;
559 	catu_desc.ops = &catu_ops;
560 
561 	drvdata->csdev = coresight_register(&catu_desc);
562 	if (IS_ERR(drvdata->csdev))
563 		ret = PTR_ERR(drvdata->csdev);
564 out:
565 	return ret;
566 }
567 
568 static int catu_probe(struct amba_device *adev, const struct amba_id *id)
569 {
570 	struct catu_drvdata *drvdata;
571 	int ret;
572 
573 	drvdata = devm_kzalloc(&adev->dev, sizeof(*drvdata), GFP_KERNEL);
574 	if (!drvdata)
575 		return -ENOMEM;
576 
577 	amba_set_drvdata(adev, drvdata);
578 	ret = __catu_probe(&adev->dev, &adev->res);
579 	if (!ret)
580 		pm_runtime_put(&adev->dev);
581 
582 	return ret;
583 }
584 
585 static void __catu_remove(struct device *dev)
586 {
587 	struct catu_drvdata *drvdata = dev_get_drvdata(dev);
588 
589 	coresight_unregister(drvdata->csdev);
590 }
591 
592 static void catu_remove(struct amba_device *adev)
593 {
594 	__catu_remove(&adev->dev);
595 }
596 
597 static struct amba_id catu_ids[] = {
598 	CS_AMBA_ID(0x000bb9ee),
599 	{},
600 };
601 
602 MODULE_DEVICE_TABLE(amba, catu_ids);
603 
604 static struct amba_driver catu_driver = {
605 	.drv = {
606 		.name			= "coresight-catu",
607 		.suppress_bind_attrs	= true,
608 	},
609 	.probe				= catu_probe,
610 	.remove				= catu_remove,
611 	.id_table			= catu_ids,
612 };
613 
614 static int catu_platform_probe(struct platform_device *pdev)
615 {
616 	struct resource *res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
617 	struct catu_drvdata *drvdata;
618 	int ret = 0;
619 
620 	drvdata = devm_kzalloc(&pdev->dev, sizeof(*drvdata), GFP_KERNEL);
621 	if (!drvdata)
622 		return -ENOMEM;
623 
624 	drvdata->pclk = coresight_get_enable_apb_pclk(&pdev->dev);
625 	if (IS_ERR(drvdata->pclk))
626 		return -ENODEV;
627 
628 	pm_runtime_get_noresume(&pdev->dev);
629 	pm_runtime_set_active(&pdev->dev);
630 	pm_runtime_enable(&pdev->dev);
631 
632 	dev_set_drvdata(&pdev->dev, drvdata);
633 	ret = __catu_probe(&pdev->dev, res);
634 	pm_runtime_put(&pdev->dev);
635 	if (ret) {
636 		pm_runtime_disable(&pdev->dev);
637 		if (!IS_ERR_OR_NULL(drvdata->pclk))
638 			clk_put(drvdata->pclk);
639 	}
640 
641 	return ret;
642 }
643 
644 static void catu_platform_remove(struct platform_device *pdev)
645 {
646 	struct catu_drvdata *drvdata = dev_get_drvdata(&pdev->dev);
647 
648 	if (WARN_ON(!drvdata))
649 		return;
650 
651 	__catu_remove(&pdev->dev);
652 	pm_runtime_disable(&pdev->dev);
653 	if (!IS_ERR_OR_NULL(drvdata->pclk))
654 		clk_put(drvdata->pclk);
655 }
656 
657 #ifdef CONFIG_PM
658 static int catu_runtime_suspend(struct device *dev)
659 {
660 	struct catu_drvdata *drvdata = dev_get_drvdata(dev);
661 
662 	if (drvdata && !IS_ERR_OR_NULL(drvdata->pclk))
663 		clk_disable_unprepare(drvdata->pclk);
664 	return 0;
665 }
666 
667 static int catu_runtime_resume(struct device *dev)
668 {
669 	struct catu_drvdata *drvdata = dev_get_drvdata(dev);
670 
671 	if (drvdata && !IS_ERR_OR_NULL(drvdata->pclk))
672 		clk_prepare_enable(drvdata->pclk);
673 	return 0;
674 }
675 #endif
676 
677 static const struct dev_pm_ops catu_dev_pm_ops = {
678 	SET_RUNTIME_PM_OPS(catu_runtime_suspend, catu_runtime_resume, NULL)
679 };
680 
681 #ifdef CONFIG_ACPI
682 static const struct acpi_device_id catu_acpi_ids[] = {
683 	{"ARMHC9CA", 0, 0, 0}, /* ARM CoreSight CATU */
684 	{},
685 };
686 
687 MODULE_DEVICE_TABLE(acpi, catu_acpi_ids);
688 #endif
689 
690 static struct platform_driver catu_platform_driver = {
691 	.probe	= catu_platform_probe,
692 	.remove_new = catu_platform_remove,
693 	.driver	= {
694 		.name			= "coresight-catu-platform",
695 		.acpi_match_table	= ACPI_PTR(catu_acpi_ids),
696 		.suppress_bind_attrs	= true,
697 		.pm			= &catu_dev_pm_ops,
698 	},
699 };
700 
701 static int __init catu_init(void)
702 {
703 	int ret;
704 
705 	ret = coresight_init_driver("catu", &catu_driver, &catu_platform_driver);
706 	tmc_etr_set_catu_ops(&etr_catu_buf_ops);
707 	return ret;
708 }
709 
710 static void __exit catu_exit(void)
711 {
712 	tmc_etr_remove_catu_ops();
713 	coresight_remove_driver(&catu_driver, &catu_platform_driver);
714 }
715 
716 module_init(catu_init);
717 module_exit(catu_exit);
718 
719 MODULE_AUTHOR("Suzuki K Poulose <suzuki.poulose@arm.com>");
720 MODULE_DESCRIPTION("Arm CoreSight Address Translation Unit (CATU) Driver");
721 MODULE_LICENSE("GPL v2");
722