svn commit: r357370 - head/sys/riscv/sifive

Mitchell Horne mhorne at FreeBSD.org
Sat Feb 1 17:12:16 UTC 2020


Author: mhorne
Date: Sat Feb  1 17:12:15 2020
New Revision: 357370
URL: https://svnweb.freebsd.org/changeset/base/357370

Log:
  prci: fix up compat
  
  Add two additional compat strings that can be used to identify the PRCI.
  
  With newer device trees the PRCI has two parents, hfclk and rtcclk, so
  allow the driver to attach when more than one parent is found.
  
  Reviewed by:	kp
  Differential Revision:	https://reviews.freebsd.org/D23405

Modified:
  head/sys/riscv/sifive/fu540_prci.c

Modified: head/sys/riscv/sifive/fu540_prci.c
==============================================================================
--- head/sys/riscv/sifive/fu540_prci.c	Sat Feb  1 17:09:56 2020	(r357369)
+++ head/sys/riscv/sifive/fu540_prci.c	Sat Feb  1 17:12:15 2020	(r357370)
@@ -52,6 +52,13 @@ __FBSDID("$FreeBSD$");
 
 #include <gnu/dts/include/dt-bindings/clock/sifive-fu540-prci.h>
 
+static struct ofw_compat_data compat_data[] = {
+	{ "sifive,aloeprci0",		1 },
+	{ "sifive,ux00prci0",		1 },
+	{ "sifive,fu540-c000-prci",	1 },
+	{ NULL,				0 },
+};
+
 static struct resource_spec prci_spec[] = {
 	{ SYS_RES_MEMORY, 0, RF_ACTIVE },
 	RESOURCE_SPEC_END
@@ -177,7 +184,7 @@ prci_probe(device_t dev)
 	if (!ofw_bus_status_okay(dev))
 		return (ENXIO);
 
-	if (!ofw_bus_is_compatible(dev, "sifive,aloeprci0"))
+	if (ofw_bus_search_compatible(dev, compat_data)->ocd_data == 0)
 		return (ENXIO);
 
 	device_set_desc(dev, "SiFive FU540 Power Reset Clocking Interrupt");
@@ -229,7 +236,7 @@ prci_attach(device_t dev)
 	node = ofw_bus_get_node(dev);
 	error = ofw_bus_parse_xref_list_get_length(node, "clocks",
 	    "#clock-cells", &ncells);
-	if (error != 0 || ncells != 1) {
+	if (error != 0 || ncells < 1) {
 		device_printf(dev, "couldn't find parent clock\n");
 		goto fail;
 	}


More information about the svn-src-head mailing list