blob: d9b3cf0f410c8cfb509a4c1a4d6c83fde6fe33c6 [file] [log] [blame]
David Brazdil0f672f62019-12-10 10:32:29 +00001/* SPDX-License-Identifier: GPL-2.0-only */
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00002/*
3 * Copyright (C) ST-Ericsson SA 2011
4 * Author: Lee Jones <lee.jones@linaro.org> for ST-Ericsson.
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00005 */
6#ifndef __SOC_BUS_H
7#define __SOC_BUS_H
8
9#include <linux/device.h>
10
11struct soc_device_attribute {
12 const char *machine;
13 const char *family;
14 const char *revision;
David Brazdil0f672f62019-12-10 10:32:29 +000015 const char *serial_number;
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000016 const char *soc_id;
17 const void *data;
Olivier Deprez157378f2022-04-04 15:47:50 +020018 const struct attribute_group *custom_attr_group;
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000019};
20
21/**
22 * soc_device_register - register SoC as a device
23 * @soc_plat_dev_attr: Attributes passed from platform to be attributed to a SoC
24 */
25struct soc_device *soc_device_register(
26 struct soc_device_attribute *soc_plat_dev_attr);
27
28/**
29 * soc_device_unregister - unregister SoC device
30 * @dev: SoC device to be unregistered
31 */
32void soc_device_unregister(struct soc_device *soc_dev);
33
34/**
35 * soc_device_to_device - helper function to fetch struct device
36 * @soc: Previously registered SoC device container
37 */
38struct device *soc_device_to_device(struct soc_device *soc);
39
40#ifdef CONFIG_SOC_BUS
41const struct soc_device_attribute *soc_device_match(
42 const struct soc_device_attribute *matches);
43#else
44static inline const struct soc_device_attribute *soc_device_match(
45 const struct soc_device_attribute *matches) { return NULL; }
46#endif
47
48#endif /* __SOC_BUS_H */