aboutsummaryrefslogtreecommitdiff
path: root/arch/riscv/lib/sifive_cache.c
blob: d8fe1dfa95887d21af721033c0795d631325cff9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// SPDX-License-Identifier: GPL-2.0+
/*
 * Copyright (C) 2021 SiFive, Inc
 */

#include <cache.h>
#include <cpu_func.h>
#include <log.h>
#include <dm.h>
#include <dm/device-internal.h>
#include <dm/uclass-internal.h>

#ifndef CONFIG_SPL_BUILD
void enable_caches(void)
{
	struct udevice *dev;
	int ret;

	/* Enable ways of ccache */
	ret = uclass_get_device_by_driver(UCLASS_CACHE,
					  DM_DRIVER_GET(sifive_ccache),
					  &dev);
	if (ret) {
		log_debug("Cannot enable cache ways");
	} else {
		ret = cache_enable(dev);
		if (ret)
			log_debug("ccache enable failed");
	}
}
#else
static inline void probe_cache_device(struct driver *driver, struct udevice *dev)
{
	for (uclass_find_first_device(UCLASS_CACHE, &dev);
	     dev;
	     uclass_find_next_device(&dev)) {
		if (dev->driver == driver)
			device_probe(dev);
	}
}

void enable_caches(void)
{
	struct udevice *dev = NULL;

	probe_cache_device(DM_DRIVER_GET(sifive_pl2), dev);
}
#endif /* !CONFIG_SPL_BUILD */