61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
// SPDX-License-Identifier: GPL-2.0+
 | 
						|
/*
 | 
						|
 * Copyright (C) 2021 Mark Kettenis <kettenis@openbsd.org>
 | 
						|
 */
 | 
						|
 | 
						|
#include <common.h>
 | 
						|
#include <cpu_func.h>
 | 
						|
#include <dm.h>
 | 
						|
#include <asm/io.h>
 | 
						|
 | 
						|
#define DART_PARAMS2		0x0004
 | 
						|
#define  DART_PARAMS2_BYPASS_SUPPORT	BIT(0)
 | 
						|
#define DART_TLB_OP		0x0020
 | 
						|
#define  DART_TLB_OP_OPMASK	(0xfff << 20)
 | 
						|
#define  DART_TLB_OP_FLUSH	(0x001 << 20)
 | 
						|
#define  DART_TLB_OP_BUSY	BIT(2)
 | 
						|
#define DART_TLB_OP_SIDMASK	0x0034
 | 
						|
#define DART_ERROR_STATUS	0x0040
 | 
						|
#define DART_TCR(sid)		(0x0100 + 4 * (sid))
 | 
						|
#define  DART_TCR_TRANSLATE_ENABLE	BIT(7)
 | 
						|
#define  DART_TCR_BYPASS_DART		BIT(8)
 | 
						|
#define  DART_TCR_BYPASS_DAPF		BIT(12)
 | 
						|
#define DART_TTBR(sid, idx)	(0x0200 + 16 * (sid) + 4 * (idx))
 | 
						|
#define  DART_TTBR_VALID	BIT(31)
 | 
						|
#define  DART_TTBR_SHIFT	12
 | 
						|
 | 
						|
static int apple_dart_probe(struct udevice *dev)
 | 
						|
{
 | 
						|
	void *base;
 | 
						|
	int sid, i;
 | 
						|
 | 
						|
	base = dev_read_addr_ptr(dev);
 | 
						|
	if (!base)
 | 
						|
		return -EINVAL;
 | 
						|
 | 
						|
	u32 params2 = readl(base + DART_PARAMS2);
 | 
						|
	if (params2 & DART_PARAMS2_BYPASS_SUPPORT) {
 | 
						|
		for (sid = 0; sid < 16; sid++) {
 | 
						|
			writel(DART_TCR_BYPASS_DART | DART_TCR_BYPASS_DAPF,
 | 
						|
			       base + DART_TCR(sid));
 | 
						|
			for (i = 0; i < 4; i++)
 | 
						|
				writel(0, base + DART_TTBR(sid, i));
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	return 0;
 | 
						|
}
 | 
						|
 | 
						|
static const struct udevice_id apple_dart_ids[] = {
 | 
						|
	{ .compatible = "apple,t8103-dart" },
 | 
						|
	{ .compatible = "apple,t6000-dart" },
 | 
						|
	{ /* sentinel */ }
 | 
						|
};
 | 
						|
 | 
						|
U_BOOT_DRIVER(apple_dart) = {
 | 
						|
	.name = "apple_dart",
 | 
						|
	.id = UCLASS_IOMMU,
 | 
						|
	.of_match = apple_dart_ids,
 | 
						|
	.probe = apple_dart_probe
 | 
						|
};
 |