diff mbox

[U-Boot,v2,07/20] dm: Implement a CPU uclass

Message ID 1430274322-14383-8-git-send-email-sjg@chromium.org
State Accepted
Delegated to: Simon Glass
Headers show

Commit Message

Simon Glass April 29, 2015, 2:25 a.m. UTC
It is useful to be able to keep track of the available CPUs in a multi-CPU
system. This uclass is mostly intended for use with SMP systems.

The uclass provides methods for getting basic information about each CPU.

Signed-off-by: Simon Glass <sjg@chromium.org>
---

Changes in v2:
- Change header guard to capital letters
- Change get_info() in function comment to cpu_get_info()

 drivers/Kconfig          |  2 ++
 drivers/Makefile         |  1 +
 drivers/cpu/Kconfig      |  8 +++++
 drivers/cpu/Makefile     |  7 ++++
 drivers/cpu/cpu-uclass.c | 61 +++++++++++++++++++++++++++++++++++
 include/cpu.h            | 84 ++++++++++++++++++++++++++++++++++++++++++++++++
 include/dm/uclass-id.h   |  1 +
 7 files changed, 164 insertions(+)
 create mode 100644 drivers/cpu/Kconfig
 create mode 100644 drivers/cpu/Makefile
 create mode 100644 drivers/cpu/cpu-uclass.c
 create mode 100644 include/cpu.h

Comments

Bin Meng April 29, 2015, 5:01 a.m. UTC | #1
Hi Simon,

On Wed, Apr 29, 2015 at 10:25 AM, Simon Glass <sjg@chromium.org> wrote:
> It is useful to be able to keep track of the available CPUs in a multi-CPU
> system. This uclass is mostly intended for use with SMP systems.
>
> The uclass provides methods for getting basic information about each CPU.
>
> Signed-off-by: Simon Glass <sjg@chromium.org>
> ---

Reviewed-by: Bin Meng <bmeng.cn@gmail.com>

But one comment raised previously not addressed below.

>
> Changes in v2:
> - Change header guard to capital letters
> - Change get_info() in function comment to cpu_get_info()
>
>  drivers/Kconfig          |  2 ++
>  drivers/Makefile         |  1 +
>  drivers/cpu/Kconfig      |  8 +++++
>  drivers/cpu/Makefile     |  7 ++++
>  drivers/cpu/cpu-uclass.c | 61 +++++++++++++++++++++++++++++++++++
>  include/cpu.h            | 84 ++++++++++++++++++++++++++++++++++++++++++++++++
>  include/dm/uclass-id.h   |  1 +
>  7 files changed, 164 insertions(+)
>  create mode 100644 drivers/cpu/Kconfig
>  create mode 100644 drivers/cpu/Makefile
>  create mode 100644 drivers/cpu/cpu-uclass.c
>  create mode 100644 include/cpu.h
>
> diff --git a/drivers/Kconfig b/drivers/Kconfig
> index 941aa0c..1f40887 100644
> --- a/drivers/Kconfig
> +++ b/drivers/Kconfig
> @@ -2,6 +2,8 @@ menu "Device Drivers"
>
>  source "drivers/core/Kconfig"
>
> +source "drivers/cpu/Kconfig"
> +
>  source "drivers/demo/Kconfig"
>
>  source "drivers/pci/Kconfig"
> diff --git a/drivers/Makefile b/drivers/Makefile
> index 5ef58c0..405b64b 100644
> --- a/drivers/Makefile
> +++ b/drivers/Makefile
> @@ -3,6 +3,7 @@ obj-$(CONFIG_DM_DEMO) += demo/
>  obj-$(CONFIG_BIOSEMU) += bios_emulator/
>  obj-y += block/
>  obj-$(CONFIG_BOOTCOUNT_LIMIT) += bootcount/
> +obj-$(CONFIG_CPU) += cpu/
>  obj-y += crypto/
>  obj-$(CONFIG_FPGA) += fpga/
>  obj-y += hwmon/
> diff --git a/drivers/cpu/Kconfig b/drivers/cpu/Kconfig
> new file mode 100644
> index 0000000..0d1424d
> --- /dev/null
> +++ b/drivers/cpu/Kconfig
> @@ -0,0 +1,8 @@
> +config CPU

Should it be DM_CPU? Like other DM drivers (DM_SERIAL, DM_I2C, etc).

> +       bool "Enable CPU drivers using Driver Model"
> +       help
> +         This allows drivers to be provided for CPUs and their type to be
> +         specified in the board's device tree. For boards which support
> +         multiple CPUs, then normally have to be set up in U-Boot so that
> +         they can work correctly in the OS. This provides a framework for
> +         finding out information about available CPUs and making changes.

[snip]

Regards,
Bin
Simon Glass April 29, 2015, 1:32 p.m. UTC | #2
Hi Bin,

On 28 April 2015 at 23:01, Bin Meng <bmeng.cn@gmail.com> wrote:
> Hi Simon,
>
> On Wed, Apr 29, 2015 at 10:25 AM, Simon Glass <sjg@chromium.org> wrote:
>> It is useful to be able to keep track of the available CPUs in a multi-CPU
>> system. This uclass is mostly intended for use with SMP systems.
>>
>> The uclass provides methods for getting basic information about each CPU.
>>
>> Signed-off-by: Simon Glass <sjg@chromium.org>
>> ---
>
> Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
>
> But one comment raised previously not addressed below.
>
>>
>> Changes in v2:
>> - Change header guard to capital letters
>> - Change get_info() in function comment to cpu_get_info()
>>
>>  drivers/Kconfig          |  2 ++
>>  drivers/Makefile         |  1 +
>>  drivers/cpu/Kconfig      |  8 +++++
>>  drivers/cpu/Makefile     |  7 ++++
>>  drivers/cpu/cpu-uclass.c | 61 +++++++++++++++++++++++++++++++++++
>>  include/cpu.h            | 84 ++++++++++++++++++++++++++++++++++++++++++++++++
>>  include/dm/uclass-id.h   |  1 +
>>  7 files changed, 164 insertions(+)
>>  create mode 100644 drivers/cpu/Kconfig
>>  create mode 100644 drivers/cpu/Makefile
>>  create mode 100644 drivers/cpu/cpu-uclass.c
>>  create mode 100644 include/cpu.h
>>
>> diff --git a/drivers/Kconfig b/drivers/Kconfig
>> index 941aa0c..1f40887 100644
>> --- a/drivers/Kconfig
>> +++ b/drivers/Kconfig
>> @@ -2,6 +2,8 @@ menu "Device Drivers"
>>
>>  source "drivers/core/Kconfig"
>>
>> +source "drivers/cpu/Kconfig"
>> +
>>  source "drivers/demo/Kconfig"
>>
>>  source "drivers/pci/Kconfig"
>> diff --git a/drivers/Makefile b/drivers/Makefile
>> index 5ef58c0..405b64b 100644
>> --- a/drivers/Makefile
>> +++ b/drivers/Makefile
>> @@ -3,6 +3,7 @@ obj-$(CONFIG_DM_DEMO) += demo/
>>  obj-$(CONFIG_BIOSEMU) += bios_emulator/
>>  obj-y += block/
>>  obj-$(CONFIG_BOOTCOUNT_LIMIT) += bootcount/
>> +obj-$(CONFIG_CPU) += cpu/
>>  obj-y += crypto/
>>  obj-$(CONFIG_FPGA) += fpga/
>>  obj-y += hwmon/
>> diff --git a/drivers/cpu/Kconfig b/drivers/cpu/Kconfig
>> new file mode 100644
>> index 0000000..0d1424d
>> --- /dev/null
>> +++ b/drivers/cpu/Kconfig
>> @@ -0,0 +1,8 @@
>> +config CPU
>
> Should it be DM_CPU? Like other DM drivers (DM_SERIAL, DM_I2C, etc).
>
>> +       bool "Enable CPU drivers using Driver Model"
>> +       help
>> +         This allows drivers to be provided for CPUs and their type to be
>> +         specified in the board's device tree. For boards which support
>> +         multiple CPUs, then normally have to be set up in U-Boot so that
>> +         they can work correctly in the OS. This provides a framework for
>> +         finding out information about available CPUs and making changes.
>

I prefer only using the DM prefix when there is a non-DM option. In
fact the way it is supposed to work is that eventually the
CONFIG_DM... option goes away. When every board uses DM for a
subsystem we should be able to drop it.

CPU support (or whatever we call it) will only be available with
driver model, so I don't think we need separate CONFIG_CPU and
CONFIG_DM_CPU options.

Regards,
Simon
Bin Meng April 29, 2015, 2:07 p.m. UTC | #3
Hi Simon,

On Wed, Apr 29, 2015 at 9:32 PM, Simon Glass <sjg@chromium.org> wrote:
> Hi Bin,
>
> On 28 April 2015 at 23:01, Bin Meng <bmeng.cn@gmail.com> wrote:
>> Hi Simon,
>>
>> On Wed, Apr 29, 2015 at 10:25 AM, Simon Glass <sjg@chromium.org> wrote:
>>> It is useful to be able to keep track of the available CPUs in a multi-CPU
>>> system. This uclass is mostly intended for use with SMP systems.
>>>
>>> The uclass provides methods for getting basic information about each CPU.
>>>
>>> Signed-off-by: Simon Glass <sjg@chromium.org>
>>> ---
>>
>> Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
>>
>> But one comment raised previously not addressed below.
>>
>>>
>>> Changes in v2:
>>> - Change header guard to capital letters
>>> - Change get_info() in function comment to cpu_get_info()
>>>
>>>  drivers/Kconfig          |  2 ++
>>>  drivers/Makefile         |  1 +
>>>  drivers/cpu/Kconfig      |  8 +++++
>>>  drivers/cpu/Makefile     |  7 ++++
>>>  drivers/cpu/cpu-uclass.c | 61 +++++++++++++++++++++++++++++++++++
>>>  include/cpu.h            | 84 ++++++++++++++++++++++++++++++++++++++++++++++++
>>>  include/dm/uclass-id.h   |  1 +
>>>  7 files changed, 164 insertions(+)
>>>  create mode 100644 drivers/cpu/Kconfig
>>>  create mode 100644 drivers/cpu/Makefile
>>>  create mode 100644 drivers/cpu/cpu-uclass.c
>>>  create mode 100644 include/cpu.h
>>>
>>> diff --git a/drivers/Kconfig b/drivers/Kconfig
>>> index 941aa0c..1f40887 100644
>>> --- a/drivers/Kconfig
>>> +++ b/drivers/Kconfig
>>> @@ -2,6 +2,8 @@ menu "Device Drivers"
>>>
>>>  source "drivers/core/Kconfig"
>>>
>>> +source "drivers/cpu/Kconfig"
>>> +
>>>  source "drivers/demo/Kconfig"
>>>
>>>  source "drivers/pci/Kconfig"
>>> diff --git a/drivers/Makefile b/drivers/Makefile
>>> index 5ef58c0..405b64b 100644
>>> --- a/drivers/Makefile
>>> +++ b/drivers/Makefile
>>> @@ -3,6 +3,7 @@ obj-$(CONFIG_DM_DEMO) += demo/
>>>  obj-$(CONFIG_BIOSEMU) += bios_emulator/
>>>  obj-y += block/
>>>  obj-$(CONFIG_BOOTCOUNT_LIMIT) += bootcount/
>>> +obj-$(CONFIG_CPU) += cpu/
>>>  obj-y += crypto/
>>>  obj-$(CONFIG_FPGA) += fpga/
>>>  obj-y += hwmon/
>>> diff --git a/drivers/cpu/Kconfig b/drivers/cpu/Kconfig
>>> new file mode 100644
>>> index 0000000..0d1424d
>>> --- /dev/null
>>> +++ b/drivers/cpu/Kconfig
>>> @@ -0,0 +1,8 @@
>>> +config CPU
>>
>> Should it be DM_CPU? Like other DM drivers (DM_SERIAL, DM_I2C, etc).
>>
>>> +       bool "Enable CPU drivers using Driver Model"
>>> +       help
>>> +         This allows drivers to be provided for CPUs and their type to be
>>> +         specified in the board's device tree. For boards which support
>>> +         multiple CPUs, then normally have to be set up in U-Boot so that
>>> +         they can work correctly in the OS. This provides a framework for
>>> +         finding out information about available CPUs and making changes.
>>
>
> I prefer only using the DM prefix when there is a non-DM option. In
> fact the way it is supposed to work is that eventually the
> CONFIG_DM... option goes away. When every board uses DM for a
> subsystem we should be able to drop it.
>

Good to know that those CONFIG_DM_xxx will eventually go away.

> CPU support (or whatever we call it) will only be available with
> driver model, so I don't think we need separate CONFIG_CPU and
> CONFIG_DM_CPU options.
>

OK.

Regards,
Bin
Simon Glass April 30, 2015, 4:22 a.m. UTC | #4
On 29 April 2015 at 08:07, Bin Meng <bmeng.cn@gmail.com> wrote:
> Hi Simon,
>
> On Wed, Apr 29, 2015 at 9:32 PM, Simon Glass <sjg@chromium.org> wrote:
>> Hi Bin,
>>
>> On 28 April 2015 at 23:01, Bin Meng <bmeng.cn@gmail.com> wrote:
>>> Hi Simon,
>>>
>>> On Wed, Apr 29, 2015 at 10:25 AM, Simon Glass <sjg@chromium.org> wrote:
>>>> It is useful to be able to keep track of the available CPUs in a multi-CPU
>>>> system. This uclass is mostly intended for use with SMP systems.
>>>>
>>>> The uclass provides methods for getting basic information about each CPU.
>>>>
>>>> Signed-off-by: Simon Glass <sjg@chromium.org>
>>>> ---
>>>
>>> Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
>>>

Applied to u-boot-x86.

>>> But one comment raised previously not addressed below.
>>>
>>>>
>>>> Changes in v2:
>>>> - Change header guard to capital letters
>>>> - Change get_info() in function comment to cpu_get_info()
>>>>
>>>>  drivers/Kconfig          |  2 ++
>>>>  drivers/Makefile         |  1 +
>>>>  drivers/cpu/Kconfig      |  8 +++++
>>>>  drivers/cpu/Makefile     |  7 ++++
>>>>  drivers/cpu/cpu-uclass.c | 61 +++++++++++++++++++++++++++++++++++
>>>>  include/cpu.h            | 84 ++++++++++++++++++++++++++++++++++++++++++++++++
>>>>  include/dm/uclass-id.h   |  1 +
>>>>  7 files changed, 164 insertions(+)
>>>>  create mode 100644 drivers/cpu/Kconfig
>>>>  create mode 100644 drivers/cpu/Makefile
>>>>  create mode 100644 drivers/cpu/cpu-uclass.c
>>>>  create mode 100644 include/cpu.h
>>>>
>>>> diff --git a/drivers/Kconfig b/drivers/Kconfig
>>>> index 941aa0c..1f40887 100644
>>>> --- a/drivers/Kconfig
>>>> +++ b/drivers/Kconfig
>>>> @@ -2,6 +2,8 @@ menu "Device Drivers"
>>>>
>>>>  source "drivers/core/Kconfig"
>>>>
>>>> +source "drivers/cpu/Kconfig"
>>>> +
>>>>  source "drivers/demo/Kconfig"
>>>>
>>>>  source "drivers/pci/Kconfig"
>>>> diff --git a/drivers/Makefile b/drivers/Makefile
>>>> index 5ef58c0..405b64b 100644
>>>> --- a/drivers/Makefile
>>>> +++ b/drivers/Makefile
>>>> @@ -3,6 +3,7 @@ obj-$(CONFIG_DM_DEMO) += demo/
>>>>  obj-$(CONFIG_BIOSEMU) += bios_emulator/
>>>>  obj-y += block/
>>>>  obj-$(CONFIG_BOOTCOUNT_LIMIT) += bootcount/
>>>> +obj-$(CONFIG_CPU) += cpu/
>>>>  obj-y += crypto/
>>>>  obj-$(CONFIG_FPGA) += fpga/
>>>>  obj-y += hwmon/
>>>> diff --git a/drivers/cpu/Kconfig b/drivers/cpu/Kconfig
>>>> new file mode 100644
>>>> index 0000000..0d1424d
>>>> --- /dev/null
>>>> +++ b/drivers/cpu/Kconfig
>>>> @@ -0,0 +1,8 @@
>>>> +config CPU
>>>
>>> Should it be DM_CPU? Like other DM drivers (DM_SERIAL, DM_I2C, etc).
>>>
>>>> +       bool "Enable CPU drivers using Driver Model"
>>>> +       help
>>>> +         This allows drivers to be provided for CPUs and their type to be
>>>> +         specified in the board's device tree. For boards which support
>>>> +         multiple CPUs, then normally have to be set up in U-Boot so that
>>>> +         they can work correctly in the OS. This provides a framework for
>>>> +         finding out information about available CPUs and making changes.
>>>
>>
>> I prefer only using the DM prefix when there is a non-DM option. In
>> fact the way it is supposed to work is that eventually the
>> CONFIG_DM... option goes away. When every board uses DM for a
>> subsystem we should be able to drop it.
>>
>
> Good to know that those CONFIG_DM_xxx will eventually go away.
>
>> CPU support (or whatever we call it) will only be available with
>> driver model, so I don't think we need separate CONFIG_CPU and
>> CONFIG_DM_CPU options.
>>
>
> OK.
>
> Regards,
> Bin
diff mbox

Patch

diff --git a/drivers/Kconfig b/drivers/Kconfig
index 941aa0c..1f40887 100644
--- a/drivers/Kconfig
+++ b/drivers/Kconfig
@@ -2,6 +2,8 @@  menu "Device Drivers"
 
 source "drivers/core/Kconfig"
 
+source "drivers/cpu/Kconfig"
+
 source "drivers/demo/Kconfig"
 
 source "drivers/pci/Kconfig"
diff --git a/drivers/Makefile b/drivers/Makefile
index 5ef58c0..405b64b 100644
--- a/drivers/Makefile
+++ b/drivers/Makefile
@@ -3,6 +3,7 @@  obj-$(CONFIG_DM_DEMO) += demo/
 obj-$(CONFIG_BIOSEMU) += bios_emulator/
 obj-y += block/
 obj-$(CONFIG_BOOTCOUNT_LIMIT) += bootcount/
+obj-$(CONFIG_CPU) += cpu/
 obj-y += crypto/
 obj-$(CONFIG_FPGA) += fpga/
 obj-y += hwmon/
diff --git a/drivers/cpu/Kconfig b/drivers/cpu/Kconfig
new file mode 100644
index 0000000..0d1424d
--- /dev/null
+++ b/drivers/cpu/Kconfig
@@ -0,0 +1,8 @@ 
+config CPU
+	bool "Enable CPU drivers using Driver Model"
+	help
+	  This allows drivers to be provided for CPUs and their type to be
+	  specified in the board's device tree. For boards which support
+	  multiple CPUs, then normally have to be set up in U-Boot so that
+	  they can work correctly in the OS. This provides a framework for
+	  finding out information about available CPUs and making changes.
diff --git a/drivers/cpu/Makefile b/drivers/cpu/Makefile
new file mode 100644
index 0000000..8710160
--- /dev/null
+++ b/drivers/cpu/Makefile
@@ -0,0 +1,7 @@ 
+#
+# Copyright (c) 2015 Google, Inc
+# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
+#
+# SPDX-License-Identifier:      GPL-2.0+
+#
+obj-$(CONFIG_CPU) += cpu-uclass.o
diff --git a/drivers/cpu/cpu-uclass.c b/drivers/cpu/cpu-uclass.c
new file mode 100644
index 0000000..ab18ee2
--- /dev/null
+++ b/drivers/cpu/cpu-uclass.c
@@ -0,0 +1,61 @@ 
+/*
+ * Copyright (C) 2015 Google, Inc
+ * Written by Simon Glass <sjg@chromium.org>
+ *
+ * SPDX-License-Identifier:	GPL-2.0+
+ */
+
+#include <common.h>
+#include <cpu.h>
+#include <dm.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_desc)
+		return -ENOSYS;
+
+	return ops->get_info(dev, info);
+}
+
+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;
+	int node;
+	int ret;
+
+	node = fdt_path_offset(gd->fdt_blob, "/cpus");
+	if (node < 0)
+		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,
+};
diff --git a/include/cpu.h b/include/cpu.h
new file mode 100644
index 0000000..34c60bc
--- /dev/null
+++ b/include/cpu.h
@@ -0,0 +1,84 @@ 
+/*
+ * Copyright (c) 2015 Google, Inc
+ * Written by Simon Glass <sjg@chromium.org>
+ *
+ * SPDX-License-Identifier:	GPL-2.0+
+ */
+
+#ifndef __CPU_H
+#define __CPU_H
+
+/**
+ * struct cpu_platdata - platform data for a CPU
+ *
+ * This can be accessed with dev_get_parent_platdata() for any UCLASS_CPU
+ * device.
+ *
+ * @cpu_id:	Platform-specific way of identifying the CPU.
+ */
+struct cpu_platdata {
+	int cpu_id;
+};
+
+/* CPU features - mostly just a placeholder for now */
+enum {
+	CPU_FEAT_L1_CACHE	= 0,	/* Supports level 1 cache */
+	CPU_FEAT_MMU		= 1,	/* Supports virtual memory */
+
+	CPU_FEAT_COUNT,
+};
+
+/**
+ * struct cpu_info - Information about a CPU
+ *
+ * @cpu_freq:	Current CPU frequency in Hz
+ * @features:	Flags for supported CPU features
+ */
+struct cpu_info {
+	ulong cpu_freq;
+	ulong features;
+};
+
+struct cpu_ops {
+	/**
+	 * get_desc() - Get a description string for a CPU
+	 *
+	 * @dev:	Device to check (UCLASS_CPU)
+	 * @buf:	Buffer to place string
+	 * @size:	Size of string space
+	 * @return 0 if OK, -ENOSPC if buffer is too small, other -ve on error
+	 */
+	int (*get_desc)(struct udevice *dev, char *buf, int size);
+
+	/**
+	 * get_info() - Get information about a CPU
+	 *
+	 * @dev:	Device to check (UCLASS_CPU)
+	 * @info:	Returns CPU info
+	 * @return 0 if OK, -ve on error
+	 */
+	int (*get_info)(struct udevice *dev, struct cpu_info *info);
+};
+
+#define cpu_get_ops(dev)        ((struct cpu_ops *)(dev)->driver->ops)
+
+/**
+ * cpu_get_desc() - Get a description string for a CPU
+ *
+ * @dev:	Device to check (UCLASS_CPU)
+ * @buf:	Buffer to place string
+ * @size:	Size of string space
+ * @return 0 if OK, -ENOSPC if buffer is too small, other -ve on error
+ */
+int cpu_get_desc(struct udevice *dev, char *buf, int size);
+
+/**
+ * cpu_get_info() - Get information about a CPU
+ *
+ * @dev:	Device to check (UCLASS_CPU)
+ * @info:	Returns CPU info
+ * @return 0 if OK, -ve on error
+ */
+int cpu_get_info(struct udevice *dev, struct cpu_info *info);
+
+#endif
diff --git a/include/dm/uclass-id.h b/include/dm/uclass-id.h
index fddfd35..395e25a 100644
--- a/include/dm/uclass-id.h
+++ b/include/dm/uclass-id.h
@@ -45,6 +45,7 @@  enum uclass_id {
 	UCLASS_USB_HUB,		/* USB hub */
 	UCLASS_USB_DEV_GENERIC,	/* USB generic device */
 	UCLASS_MASS_STORAGE,	/* Mass storage device */
+	UCLASS_CPU,		/* CPU, typically part of an SoC */
 
 	UCLASS_COUNT,
 	UCLASS_INVALID = -1,