xref: /rk3399_rockchip-uboot/drivers/misc/tegra_car.c (revision 45a26867e8158d0338ba5b99d21989a72d423209)
1bd3ee84aSStephen Warren /*
2bd3ee84aSStephen Warren  * Copyright (c) 2016, NVIDIA CORPORATION.
3bd3ee84aSStephen Warren  *
4bd3ee84aSStephen Warren  * SPDX-License-Identifier: GPL-2.0
5bd3ee84aSStephen Warren  */
6bd3ee84aSStephen Warren 
7bd3ee84aSStephen Warren #include <common.h>
8bd3ee84aSStephen Warren #include <dm.h>
9bd3ee84aSStephen Warren #include <dm/lists.h>
10bd3ee84aSStephen Warren #include <dm/root.h>
11bd3ee84aSStephen Warren 
12bd3ee84aSStephen Warren /**
13bd3ee84aSStephen Warren  * The CAR exposes multiple different services. We create a sub-device for
14bd3ee84aSStephen Warren  * each separate type of service, since each device must be of the appropriate
15bd3ee84aSStephen Warren  * UCLASS.
16bd3ee84aSStephen Warren  */
tegra_car_bpmp_bind(struct udevice * dev)17bd3ee84aSStephen Warren static int tegra_car_bpmp_bind(struct udevice *dev)
18bd3ee84aSStephen Warren {
19bd3ee84aSStephen Warren 	int ret;
20bd3ee84aSStephen Warren 	struct udevice *child;
21bd3ee84aSStephen Warren 
22bd3ee84aSStephen Warren 	debug("%s(dev=%p)\n", __func__, dev);
23bd3ee84aSStephen Warren 
24bd3ee84aSStephen Warren 	ret = device_bind_driver_to_node(dev, "tegra_car_clk", "tegra_car_clk",
25*45a26867SSimon Glass 					 dev_ofnode(dev), &child);
26bd3ee84aSStephen Warren 	if (ret)
27bd3ee84aSStephen Warren 		return ret;
28bd3ee84aSStephen Warren 
29bd3ee84aSStephen Warren 	ret = device_bind_driver_to_node(dev, "tegra_car_reset",
30*45a26867SSimon Glass 					 "tegra_car_reset", dev_ofnode(dev),
31bd3ee84aSStephen Warren 					 &child);
32bd3ee84aSStephen Warren 	if (ret)
33bd3ee84aSStephen Warren 		return ret;
34bd3ee84aSStephen Warren 
35bd3ee84aSStephen Warren 	return 0;
36bd3ee84aSStephen Warren }
37bd3ee84aSStephen Warren 
tegra_car_bpmp_probe(struct udevice * dev)38bd3ee84aSStephen Warren static int tegra_car_bpmp_probe(struct udevice *dev)
39bd3ee84aSStephen Warren {
40bd3ee84aSStephen Warren 	debug("%s(dev=%p)\n", __func__, dev);
41bd3ee84aSStephen Warren 
42bd3ee84aSStephen Warren 	return 0;
43bd3ee84aSStephen Warren }
44bd3ee84aSStephen Warren 
tegra_car_bpmp_remove(struct udevice * dev)45bd3ee84aSStephen Warren static int tegra_car_bpmp_remove(struct udevice *dev)
46bd3ee84aSStephen Warren {
47bd3ee84aSStephen Warren 	debug("%s(dev=%p)\n", __func__, dev);
48bd3ee84aSStephen Warren 
49bd3ee84aSStephen Warren 	return 0;
50bd3ee84aSStephen Warren }
51bd3ee84aSStephen Warren 
52bd3ee84aSStephen Warren static const struct udevice_id tegra_car_bpmp_ids[] = {
53bd3ee84aSStephen Warren 	{ .compatible = "nvidia,tegra20-car" },
54bd3ee84aSStephen Warren 	{ .compatible = "nvidia,tegra30-car" },
55bd3ee84aSStephen Warren 	{ .compatible = "nvidia,tegra114-car" },
56bd3ee84aSStephen Warren 	{ .compatible = "nvidia,tegra124-car" },
57bd3ee84aSStephen Warren 	{ .compatible = "nvidia,tegra210-car" },
58bd3ee84aSStephen Warren 	{ }
59bd3ee84aSStephen Warren };
60bd3ee84aSStephen Warren 
61bd3ee84aSStephen Warren U_BOOT_DRIVER(tegra_car_bpmp) = {
62bd3ee84aSStephen Warren 	.name		= "tegra_car",
63bd3ee84aSStephen Warren 	.id		= UCLASS_MISC,
64bd3ee84aSStephen Warren 	.of_match	= tegra_car_bpmp_ids,
65bd3ee84aSStephen Warren 	.bind		= tegra_car_bpmp_bind,
66bd3ee84aSStephen Warren 	.probe		= tegra_car_bpmp_probe,
67bd3ee84aSStephen Warren 	.remove		= tegra_car_bpmp_remove,
68bd3ee84aSStephen Warren };
69