xref: /openbmc/linux/drivers/hwtracing/coresight/coresight-catu.c (revision 4f727ecefefbd180de10e25b3e74c03dce3f1e75)
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/amba/bus.h>
11 #include <linux/device.h>
12 #include <linux/dma-mapping.h>
13 #include <linux/io.h>
14 #include <linux/kernel.h>
15 #include <linux/slab.h>
16 
17 #include "coresight-catu.h"
18 #include "coresight-priv.h"
19 #include "coresight-tmc.h"
20 
21 #define csdev_to_catu_drvdata(csdev)	\
22 	dev_get_drvdata(csdev->dev.parent)
23 
24 /* Verbose output for CATU table contents */
25 #ifdef CATU_DEBUG
26 #define catu_dbg(x, ...) dev_dbg(x, __VA_ARGS__)
27 #else
28 #define catu_dbg(x, ...) do {} while (0)
29 #endif
30 
31 struct catu_etr_buf {
32 	struct tmc_sg_table *catu_table;
33 	dma_addr_t sladdr;
34 };
35 
36 /*
37  * CATU uses a page size of 4KB for page tables as well as data pages.
38  * Each 64bit entry in the table has the following format.
39  *
40  *	63			12	1  0
41  *	------------------------------------
42  *	|	 Address [63-12] | SBZ	| V|
43  *	------------------------------------
44  *
45  * Where bit[0] V indicates if the address is valid or not.
46  * Each 4K table pages have upto 256 data page pointers, taking upto 2K
47  * size. There are two Link pointers, pointing to the previous and next
48  * table pages respectively at the end of the 4K page. (i.e, entry 510
49  * and 511).
50  *  E.g, a table of two pages could look like :
51  *
52  *                 Table Page 0               Table Page 1
53  * SLADDR ===> x------------------x  x--> x-----------------x
54  * INADDR    ->|  Page 0      | V |  |    | Page 256    | V | <- INADDR+1M
55  *             |------------------|  |    |-----------------|
56  * INADDR+4K ->|  Page 1      | V |  |    |                 |
57  *             |------------------|  |    |-----------------|
58  *             |  Page 2      | V |  |    |                 |
59  *             |------------------|  |    |-----------------|
60  *             |   ...        | V |  |    |    ...          |
61  *             |------------------|  |    |-----------------|
62  * INADDR+1020K|  Page 255    | V |  |    |   Page 511  | V |
63  * SLADDR+2K==>|------------------|  |    |-----------------|
64  *             |  UNUSED      |   |  |    |                 |
65  *             |------------------|  |    |                 |
66  *             |  UNUSED      |   |  |    |                 |
67  *             |------------------|  |    |                 |
68  *             |    ...       |   |  |    |                 |
69  *             |------------------|  |    |-----------------|
70  *             |   IGNORED    | 0 |  |    | Table Page 0| 1 |
71  *             |------------------|  |    |-----------------|
72  *             |  Table Page 1| 1 |--x    | IGNORED     | 0 |
73  *             x------------------x       x-----------------x
74  * SLADDR+4K==>
75  *
76  * The base input address (used by the ETR, programmed in INADDR_{LO,HI})
77  * must be aligned to 1MB (the size addressable by a single page table).
78  * The CATU maps INADDR{LO:HI} to the first page in the table pointed
79  * to by SLADDR{LO:HI} and so on.
80  *
81  */
82 typedef u64 cate_t;
83 
84 #define CATU_PAGE_SHIFT		12
85 #define CATU_PAGE_SIZE		(1UL << CATU_PAGE_SHIFT)
86 #define CATU_PAGES_PER_SYSPAGE	(PAGE_SIZE / CATU_PAGE_SIZE)
87 
88 /* Page pointers are only allocated in the first 2K half */
89 #define CATU_PTRS_PER_PAGE	((CATU_PAGE_SIZE >> 1) / sizeof(cate_t))
90 #define CATU_PTRS_PER_SYSPAGE	(CATU_PAGES_PER_SYSPAGE * CATU_PTRS_PER_PAGE)
91 #define CATU_LINK_PREV		((CATU_PAGE_SIZE / sizeof(cate_t)) - 2)
92 #define CATU_LINK_NEXT		((CATU_PAGE_SIZE / sizeof(cate_t)) - 1)
93 
94 #define CATU_ADDR_SHIFT		12
95 #define CATU_ADDR_MASK		~(((cate_t)1 << CATU_ADDR_SHIFT) - 1)
96 #define CATU_ENTRY_VALID	((cate_t)0x1)
97 #define CATU_VALID_ENTRY(addr) \
98 	(((cate_t)(addr) & CATU_ADDR_MASK) | CATU_ENTRY_VALID)
99 #define CATU_ENTRY_ADDR(entry)	((cate_t)(entry) & ~((cate_t)CATU_ENTRY_VALID))
100 
101 /* CATU expects the INADDR to be aligned to 1M. */
102 #define CATU_DEFAULT_INADDR	(1ULL << 20)
103 
104 /*
105  * catu_get_table : Retrieve the table pointers for the given @offset
106  * within the buffer. The buffer is wrapped around to a valid offset.
107  *
108  * Returns : The CPU virtual address for the beginning of the table
109  * containing the data page pointer for @offset. If @daddrp is not NULL,
110  * @daddrp points the DMA address of the beginning of the table.
111  */
112 static inline cate_t *catu_get_table(struct tmc_sg_table *catu_table,
113 				     unsigned long offset,
114 				     dma_addr_t *daddrp)
115 {
116 	unsigned long buf_size = tmc_sg_table_buf_size(catu_table);
117 	unsigned int table_nr, pg_idx, pg_offset;
118 	struct tmc_pages *table_pages = &catu_table->table_pages;
119 	void *ptr;
120 
121 	/* Make sure offset is within the range */
122 	offset %= buf_size;
123 
124 	/*
125 	 * Each table can address 1MB and a single kernel page can
126 	 * contain "CATU_PAGES_PER_SYSPAGE" CATU tables.
127 	 */
128 	table_nr = offset >> 20;
129 	/* Find the table page where the table_nr lies in */
130 	pg_idx = table_nr / CATU_PAGES_PER_SYSPAGE;
131 	pg_offset = (table_nr % CATU_PAGES_PER_SYSPAGE) * CATU_PAGE_SIZE;
132 	if (daddrp)
133 		*daddrp = table_pages->daddrs[pg_idx] + pg_offset;
134 	ptr = page_address(table_pages->pages[pg_idx]);
135 	return (cate_t *)((unsigned long)ptr + pg_offset);
136 }
137 
138 #ifdef CATU_DEBUG
139 static void catu_dump_table(struct tmc_sg_table *catu_table)
140 {
141 	int i;
142 	cate_t *table;
143 	unsigned long table_end, buf_size, offset = 0;
144 
145 	buf_size = tmc_sg_table_buf_size(catu_table);
146 	dev_dbg(catu_table->dev,
147 		"Dump table %p, tdaddr: %llx\n",
148 		catu_table, catu_table->table_daddr);
149 
150 	while (offset < buf_size) {
151 		table_end = offset + SZ_1M < buf_size ?
152 			    offset + SZ_1M : buf_size;
153 		table = catu_get_table(catu_table, offset, NULL);
154 		for (i = 0; offset < table_end; i++, offset += CATU_PAGE_SIZE)
155 			dev_dbg(catu_table->dev, "%d: %llx\n", i, table[i]);
156 		dev_dbg(catu_table->dev, "Prev : %llx, Next: %llx\n",
157 			table[CATU_LINK_PREV], table[CATU_LINK_NEXT]);
158 		dev_dbg(catu_table->dev, "== End of sub-table ===");
159 	}
160 	dev_dbg(catu_table->dev, "== End of Table ===");
161 }
162 
163 #else
164 static inline void catu_dump_table(struct tmc_sg_table *catu_table)
165 {
166 }
167 #endif
168 
169 static inline cate_t catu_make_entry(dma_addr_t addr)
170 {
171 	return addr ? CATU_VALID_ENTRY(addr) : 0;
172 }
173 
174 /*
175  * catu_populate_table : Populate the given CATU table.
176  * The table is always populated as a circular table.
177  * i.e, the "prev" link of the "first" table points to the "last"
178  * table and the "next" link of the "last" table points to the
179  * "first" table. The buffer should be made linear by calling
180  * catu_set_table().
181  */
182 static void
183 catu_populate_table(struct tmc_sg_table *catu_table)
184 {
185 	int i;
186 	int sys_pidx;	/* Index to current system data page */
187 	int catu_pidx;	/* Index of CATU page within the system data page */
188 	unsigned long offset, buf_size, table_end;
189 	dma_addr_t data_daddr;
190 	dma_addr_t prev_taddr, next_taddr, cur_taddr;
191 	cate_t *table_ptr, *next_table;
192 
193 	buf_size = tmc_sg_table_buf_size(catu_table);
194 	sys_pidx = catu_pidx = 0;
195 	offset = 0;
196 
197 	table_ptr = catu_get_table(catu_table, 0, &cur_taddr);
198 	prev_taddr = 0;	/* Prev link for the first table */
199 
200 	while (offset < buf_size) {
201 		/*
202 		 * The @offset is always 1M aligned here and we have an
203 		 * empty table @table_ptr to fill. Each table can address
204 		 * upto 1MB data buffer. The last table may have fewer
205 		 * entries if the buffer size is not aligned.
206 		 */
207 		table_end = (offset + SZ_1M) < buf_size ?
208 			    (offset + SZ_1M) : buf_size;
209 		for (i = 0; offset < table_end;
210 		     i++, offset += CATU_PAGE_SIZE) {
211 
212 			data_daddr = catu_table->data_pages.daddrs[sys_pidx] +
213 				     catu_pidx * CATU_PAGE_SIZE;
214 			catu_dbg(catu_table->dev,
215 				"[table %5ld:%03d] 0x%llx\n",
216 				(offset >> 20), i, data_daddr);
217 			table_ptr[i] = catu_make_entry(data_daddr);
218 			/* Move the pointers for data pages */
219 			catu_pidx = (catu_pidx + 1) % CATU_PAGES_PER_SYSPAGE;
220 			if (catu_pidx == 0)
221 				sys_pidx++;
222 		}
223 
224 		/*
225 		 * If we have finished all the valid entries, fill the rest of
226 		 * the table (i.e, last table page) with invalid entries,
227 		 * to fail the lookups.
228 		 */
229 		if (offset == buf_size) {
230 			memset(&table_ptr[i], 0,
231 			       sizeof(cate_t) * (CATU_PTRS_PER_PAGE - i));
232 			next_taddr = 0;
233 		} else {
234 			next_table = catu_get_table(catu_table,
235 						    offset, &next_taddr);
236 		}
237 
238 		table_ptr[CATU_LINK_PREV] = catu_make_entry(prev_taddr);
239 		table_ptr[CATU_LINK_NEXT] = catu_make_entry(next_taddr);
240 
241 		catu_dbg(catu_table->dev,
242 			"[table%5ld]: Cur: 0x%llx Prev: 0x%llx, Next: 0x%llx\n",
243 			(offset >> 20) - 1,  cur_taddr, prev_taddr, next_taddr);
244 
245 		/* Update the prev/next addresses */
246 		if (next_taddr) {
247 			prev_taddr = cur_taddr;
248 			cur_taddr = next_taddr;
249 			table_ptr = next_table;
250 		}
251 	}
252 
253 	/* Sync the table for device */
254 	tmc_sg_table_sync_table(catu_table);
255 }
256 
257 static struct tmc_sg_table *
258 catu_init_sg_table(struct device *catu_dev, int node,
259 		   ssize_t size, void **pages)
260 {
261 	int nr_tpages;
262 	struct tmc_sg_table *catu_table;
263 
264 	/*
265 	 * Each table can address upto 1MB and we can have
266 	 * CATU_PAGES_PER_SYSPAGE tables in a system page.
267 	 */
268 	nr_tpages = DIV_ROUND_UP(size, SZ_1M) / CATU_PAGES_PER_SYSPAGE;
269 	catu_table = tmc_alloc_sg_table(catu_dev, node, nr_tpages,
270 					size >> PAGE_SHIFT, pages);
271 	if (IS_ERR(catu_table))
272 		return catu_table;
273 
274 	catu_populate_table(catu_table);
275 	dev_dbg(catu_dev,
276 		"Setup table %p, size %ldKB, %d table pages\n",
277 		catu_table, (unsigned long)size >> 10,  nr_tpages);
278 	catu_dump_table(catu_table);
279 	return catu_table;
280 }
281 
282 static void catu_free_etr_buf(struct etr_buf *etr_buf)
283 {
284 	struct catu_etr_buf *catu_buf;
285 
286 	if (!etr_buf || etr_buf->mode != ETR_MODE_CATU || !etr_buf->private)
287 		return;
288 
289 	catu_buf = etr_buf->private;
290 	tmc_free_sg_table(catu_buf->catu_table);
291 	kfree(catu_buf);
292 }
293 
294 static ssize_t catu_get_data_etr_buf(struct etr_buf *etr_buf, u64 offset,
295 				     size_t len, char **bufpp)
296 {
297 	struct catu_etr_buf *catu_buf = etr_buf->private;
298 
299 	return tmc_sg_table_get_data(catu_buf->catu_table, offset, len, bufpp);
300 }
301 
302 static void catu_sync_etr_buf(struct etr_buf *etr_buf, u64 rrp, u64 rwp)
303 {
304 	struct catu_etr_buf *catu_buf = etr_buf->private;
305 	struct tmc_sg_table *catu_table = catu_buf->catu_table;
306 	u64 r_offset, w_offset;
307 
308 	/*
309 	 * ETR started off at etr_buf->hwaddr. Convert the RRP/RWP to
310 	 * offsets within the trace buffer.
311 	 */
312 	r_offset = rrp - etr_buf->hwaddr;
313 	w_offset = rwp - etr_buf->hwaddr;
314 
315 	if (!etr_buf->full) {
316 		etr_buf->len = w_offset - r_offset;
317 		if (w_offset < r_offset)
318 			etr_buf->len += etr_buf->size;
319 	} else {
320 		etr_buf->len = etr_buf->size;
321 	}
322 
323 	etr_buf->offset = r_offset;
324 	tmc_sg_table_sync_data_range(catu_table, r_offset, etr_buf->len);
325 }
326 
327 static int catu_alloc_etr_buf(struct tmc_drvdata *tmc_drvdata,
328 			      struct etr_buf *etr_buf, int node, void **pages)
329 {
330 	struct coresight_device *csdev;
331 	struct device *catu_dev;
332 	struct tmc_sg_table *catu_table;
333 	struct catu_etr_buf *catu_buf;
334 
335 	csdev = tmc_etr_get_catu_device(tmc_drvdata);
336 	if (!csdev)
337 		return -ENODEV;
338 	catu_dev = csdev->dev.parent;
339 	catu_buf = kzalloc(sizeof(*catu_buf), GFP_KERNEL);
340 	if (!catu_buf)
341 		return -ENOMEM;
342 
343 	catu_table = catu_init_sg_table(catu_dev, node, etr_buf->size, pages);
344 	if (IS_ERR(catu_table)) {
345 		kfree(catu_buf);
346 		return PTR_ERR(catu_table);
347 	}
348 
349 	etr_buf->mode = ETR_MODE_CATU;
350 	etr_buf->private = catu_buf;
351 	etr_buf->hwaddr = CATU_DEFAULT_INADDR;
352 
353 	catu_buf->catu_table = catu_table;
354 	/* Get the table base address */
355 	catu_buf->sladdr = catu_table->table_daddr;
356 
357 	return 0;
358 }
359 
360 const struct etr_buf_operations etr_catu_buf_ops = {
361 	.alloc = catu_alloc_etr_buf,
362 	.free = catu_free_etr_buf,
363 	.sync = catu_sync_etr_buf,
364 	.get_data = catu_get_data_etr_buf,
365 };
366 
367 coresight_simple_reg32(struct catu_drvdata, devid, CORESIGHT_DEVID);
368 coresight_simple_reg32(struct catu_drvdata, control, CATU_CONTROL);
369 coresight_simple_reg32(struct catu_drvdata, status, CATU_STATUS);
370 coresight_simple_reg32(struct catu_drvdata, mode, CATU_MODE);
371 coresight_simple_reg32(struct catu_drvdata, axictrl, CATU_AXICTRL);
372 coresight_simple_reg32(struct catu_drvdata, irqen, CATU_IRQEN);
373 coresight_simple_reg64(struct catu_drvdata, sladdr,
374 		       CATU_SLADDRLO, CATU_SLADDRHI);
375 coresight_simple_reg64(struct catu_drvdata, inaddr,
376 		       CATU_INADDRLO, CATU_INADDRHI);
377 
378 static struct attribute *catu_mgmt_attrs[] = {
379 	&dev_attr_devid.attr,
380 	&dev_attr_control.attr,
381 	&dev_attr_status.attr,
382 	&dev_attr_mode.attr,
383 	&dev_attr_axictrl.attr,
384 	&dev_attr_irqen.attr,
385 	&dev_attr_sladdr.attr,
386 	&dev_attr_inaddr.attr,
387 	NULL,
388 };
389 
390 static const struct attribute_group catu_mgmt_group = {
391 	.attrs = catu_mgmt_attrs,
392 	.name = "mgmt",
393 };
394 
395 static const struct attribute_group *catu_groups[] = {
396 	&catu_mgmt_group,
397 	NULL,
398 };
399 
400 
401 static inline int catu_wait_for_ready(struct catu_drvdata *drvdata)
402 {
403 	return coresight_timeout(drvdata->base,
404 				 CATU_STATUS, CATU_STATUS_READY, 1);
405 }
406 
407 static int catu_enable_hw(struct catu_drvdata *drvdata, void *data)
408 {
409 	int rc;
410 	u32 control, mode;
411 	struct etr_buf *etr_buf = data;
412 
413 	if (catu_wait_for_ready(drvdata))
414 		dev_warn(drvdata->dev, "Timeout while waiting for READY\n");
415 
416 	control = catu_read_control(drvdata);
417 	if (control & BIT(CATU_CONTROL_ENABLE)) {
418 		dev_warn(drvdata->dev, "CATU is already enabled\n");
419 		return -EBUSY;
420 	}
421 
422 	rc = coresight_claim_device_unlocked(drvdata->base);
423 	if (rc)
424 		return rc;
425 
426 	control |= BIT(CATU_CONTROL_ENABLE);
427 
428 	if (etr_buf && etr_buf->mode == ETR_MODE_CATU) {
429 		struct catu_etr_buf *catu_buf = etr_buf->private;
430 
431 		mode = CATU_MODE_TRANSLATE;
432 		catu_write_axictrl(drvdata, CATU_OS_AXICTRL);
433 		catu_write_sladdr(drvdata, catu_buf->sladdr);
434 		catu_write_inaddr(drvdata, CATU_DEFAULT_INADDR);
435 	} else {
436 		mode = CATU_MODE_PASS_THROUGH;
437 		catu_write_sladdr(drvdata, 0);
438 		catu_write_inaddr(drvdata, 0);
439 	}
440 
441 	catu_write_irqen(drvdata, 0);
442 	catu_write_mode(drvdata, mode);
443 	catu_write_control(drvdata, control);
444 	dev_dbg(drvdata->dev, "Enabled in %s mode\n",
445 		(mode == CATU_MODE_PASS_THROUGH) ?
446 		"Pass through" :
447 		"Translate");
448 	return 0;
449 }
450 
451 static int catu_enable(struct coresight_device *csdev, void *data)
452 {
453 	int rc;
454 	struct catu_drvdata *catu_drvdata = csdev_to_catu_drvdata(csdev);
455 
456 	CS_UNLOCK(catu_drvdata->base);
457 	rc = catu_enable_hw(catu_drvdata, data);
458 	CS_LOCK(catu_drvdata->base);
459 	return rc;
460 }
461 
462 static int catu_disable_hw(struct catu_drvdata *drvdata)
463 {
464 	int rc = 0;
465 
466 	catu_write_control(drvdata, 0);
467 	coresight_disclaim_device_unlocked(drvdata->base);
468 	if (catu_wait_for_ready(drvdata)) {
469 		dev_info(drvdata->dev, "Timeout while waiting for READY\n");
470 		rc = -EAGAIN;
471 	}
472 
473 	dev_dbg(drvdata->dev, "Disabled\n");
474 	return rc;
475 }
476 
477 static int catu_disable(struct coresight_device *csdev, void *__unused)
478 {
479 	int rc;
480 	struct catu_drvdata *catu_drvdata = csdev_to_catu_drvdata(csdev);
481 
482 	CS_UNLOCK(catu_drvdata->base);
483 	rc = catu_disable_hw(catu_drvdata);
484 	CS_LOCK(catu_drvdata->base);
485 	return rc;
486 }
487 
488 static const struct coresight_ops_helper catu_helper_ops = {
489 	.enable = catu_enable,
490 	.disable = catu_disable,
491 };
492 
493 static const struct coresight_ops catu_ops = {
494 	.helper_ops = &catu_helper_ops,
495 };
496 
497 static int catu_probe(struct amba_device *adev, const struct amba_id *id)
498 {
499 	int ret = 0;
500 	u32 dma_mask;
501 	struct catu_drvdata *drvdata;
502 	struct coresight_desc catu_desc;
503 	struct coresight_platform_data *pdata = NULL;
504 	struct device *dev = &adev->dev;
505 	struct device_node *np = dev->of_node;
506 	void __iomem *base;
507 
508 	if (np) {
509 		pdata = of_get_coresight_platform_data(dev, np);
510 		if (IS_ERR(pdata)) {
511 			ret = PTR_ERR(pdata);
512 			goto out;
513 		}
514 		dev->platform_data = pdata;
515 	}
516 
517 	drvdata = devm_kzalloc(dev, sizeof(*drvdata), GFP_KERNEL);
518 	if (!drvdata) {
519 		ret = -ENOMEM;
520 		goto out;
521 	}
522 
523 	drvdata->dev = dev;
524 	dev_set_drvdata(dev, drvdata);
525 	base = devm_ioremap_resource(dev, &adev->res);
526 	if (IS_ERR(base)) {
527 		ret = PTR_ERR(base);
528 		goto out;
529 	}
530 
531 	/* Setup dma mask for the device */
532 	dma_mask = readl_relaxed(base + CORESIGHT_DEVID) & 0x3f;
533 	switch (dma_mask) {
534 	case 32:
535 	case 40:
536 	case 44:
537 	case 48:
538 	case 52:
539 	case 56:
540 	case 64:
541 		break;
542 	default:
543 		/* Default to the 40bits as supported by TMC-ETR */
544 		dma_mask = 40;
545 	}
546 	ret = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(dma_mask));
547 	if (ret)
548 		goto out;
549 
550 	drvdata->base = base;
551 	catu_desc.pdata = pdata;
552 	catu_desc.dev = dev;
553 	catu_desc.groups = catu_groups;
554 	catu_desc.type = CORESIGHT_DEV_TYPE_HELPER;
555 	catu_desc.subtype.helper_subtype = CORESIGHT_DEV_SUBTYPE_HELPER_CATU;
556 	catu_desc.ops = &catu_ops;
557 	drvdata->csdev = coresight_register(&catu_desc);
558 	if (IS_ERR(drvdata->csdev))
559 		ret = PTR_ERR(drvdata->csdev);
560 	else
561 		pm_runtime_put(&adev->dev);
562 out:
563 	return ret;
564 }
565 
566 static struct amba_id catu_ids[] = {
567 	{
568 		.id	= 0x000bb9ee,
569 		.mask	= 0x000fffff,
570 	},
571 	{},
572 };
573 
574 static struct amba_driver catu_driver = {
575 	.drv = {
576 		.name			= "coresight-catu",
577 		.owner			= THIS_MODULE,
578 		.suppress_bind_attrs	= true,
579 	},
580 	.probe				= catu_probe,
581 	.id_table			= catu_ids,
582 };
583 
584 builtin_amba_driver(catu_driver);
585