| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 | // SPDX-License-Identifier: GPL-2.0+/* * Copyright (C) 2015 Google, Inc * Written by Simon Glass <sjg@chromium.org> */#include <common.h>#include <cpu.h>#include <dm.h>#include <errno.h>#include <dm/lists.h>#include <dm/root.h>int cpu_get_desc(struct udevice *dev, char *buf, int size){	struct cpu_ops *ops = cpu_get_ops(dev);	if (!ops->get_desc)		return -ENOSYS;	return ops->get_desc(dev, buf, size);}int cpu_get_info(struct udevice *dev, struct cpu_info *info){	struct cpu_ops *ops = cpu_get_ops(dev);	if (!ops->get_info)		return -ENOSYS;	return ops->get_info(dev, info);}int cpu_get_count(struct udevice *dev){	struct cpu_ops *ops = cpu_get_ops(dev);	if (!ops->get_count)		return -ENOSYS;	return ops->get_count(dev);}int cpu_get_vendor(struct udevice *dev, char *buf, int size){	struct cpu_ops *ops = cpu_get_ops(dev);	if (!ops->get_vendor)		return -ENOSYS;	return ops->get_vendor(dev, buf, size);}U_BOOT_DRIVER(cpu_bus) = {	.name	= "cpu_bus",	.id	= UCLASS_SIMPLE_BUS,	.per_child_platdata_auto_alloc_size = sizeof(struct cpu_platdata),};static int uclass_cpu_init(struct uclass *uc){	struct udevice *dev;	ofnode node;	int ret;	node = ofnode_path("/cpus");	if (!ofnode_valid(node))		return 0;	ret = device_bind_driver_to_node(dm_root(), "cpu_bus", "cpus", node,					 &dev);	return ret;}UCLASS_DRIVER(cpu) = {	.id		= UCLASS_CPU,	.name		= "cpu",	.flags		= DM_UC_FLAG_SEQ_ALIAS,	.init		= uclass_cpu_init,};
 |