blob: 3821a56f2ca145f620056afd553ee55be9e1346a [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Simon Glass6494d702014-02-26 15:59:18 -07002/*
3 * Copyright (c) 2013 Google, Inc
4 *
5 * (C) Copyright 2012
6 * Pavel Herrmann <morpheus.ibis@gmail.com>
7 * Marek Vasut <marex@denx.de>
Simon Glass6494d702014-02-26 15:59:18 -07008 */
9
10#ifndef _DM_PLATDATA_H
11#define _DM_PLATDATA_H
12
Masahiro Yamada42c23dd2014-10-07 14:49:13 +090013#include <linker_lists.h>
14
Simon Glass0040b942014-07-23 06:55:17 -060015/**
16 * struct driver_info - Information required to instantiate a device
17 *
Simon Glass97f3ee32015-07-06 12:54:22 -060018 * NOTE: Avoid using this except in extreme circumstances, where device tree
19 * is not feasible (e.g. serial driver in SPL where <8KB of SRAM is
20 * available). U-Boot's driver model uses device tree for configuration.
21 *
Masahiro Yamada81b4e752014-09-28 22:52:24 +090022 * @name: Driver name
Simon Glasscaa4daa2020-12-03 16:55:18 -070023 * @plat: Driver-specific platform data
Simon Glass4f500862020-12-03 16:55:19 -070024 * @plat_size: Size of platform data structure
Simon Glasse41651f2020-10-03 11:31:35 -060025 * @parent_idx: Index of the parent driver_info structure
Simon Glass0040b942014-07-23 06:55:17 -060026 */
Simon Glass6494d702014-02-26 15:59:18 -070027struct driver_info {
Simon Glass0040b942014-07-23 06:55:17 -060028 const char *name;
Simon Glasscaa4daa2020-12-03 16:55:18 -070029 const void *plat;
Simon Glass9fa28192016-07-04 11:58:18 -060030#if CONFIG_IS_ENABLED(OF_PLATDATA)
Simon Glass4f500862020-12-03 16:55:19 -070031 unsigned short plat_size;
Simon Glasse41651f2020-10-03 11:31:35 -060032 short parent_idx;
Simon Glass9fa28192016-07-04 11:58:18 -060033#endif
Simon Glass6494d702014-02-26 15:59:18 -070034};
35
Simon Glasse41651f2020-10-03 11:31:35 -060036#if CONFIG_IS_ENABLED(OF_PLATDATA)
37#define driver_info_parent_id(driver_info) driver_info->parent_idx
38#else
39#define driver_info_parent_id(driver_info) (-1)
40#endif
41
Simon Glass97f3ee32015-07-06 12:54:22 -060042/**
Simon Glassa294ead2020-10-03 11:31:33 -060043 * driver_rt - runtime information set up by U-Boot
44 *
45 * There is one of these for every driver_info in the linker list, indexed by
46 * the driver_info idx value.
47 *
48 * @dev: Device created from this idx
49 */
50struct driver_rt {
51 struct udevice *dev;
52};
53
54/**
Simon Glass97f3ee32015-07-06 12:54:22 -060055 * NOTE: Avoid using these except in extreme circumstances, where device tree
56 * is not feasible (e.g. serial driver in SPL where <8KB of SRAM is
57 * available). U-Boot's driver model uses device tree for configuration.
Simon Glasscb43ac12020-10-03 11:31:41 -060058 *
Simon Glass20e442a2020-12-28 20:34:54 -070059 * When of-platdata is in use, U_BOOT_DRVINFO() cannot be used outside of the
Simon Glasscaa4daa2020-12-03 16:55:18 -070060 * dt-plat.c file created by dtoc
Simon Glass97f3ee32015-07-06 12:54:22 -060061 */
Simon Glassf31fa992020-12-28 20:35:01 -070062#if CONFIG_IS_ENABLED(OF_PLATDATA) && !defined(DT_PLAT_C)
Simon Glass20e442a2020-12-28 20:34:54 -070063#define U_BOOT_DRVINFO(__name) _Static_assert(false, \
64 "Cannot use U_BOOT_DRVINFO with of-platdata. Please use devicetree instead")
Simon Glasscb43ac12020-10-03 11:31:41 -060065#else
Simon Glass20e442a2020-12-28 20:34:54 -070066#define U_BOOT_DRVINFO(__name) \
Simon Glass6494d702014-02-26 15:59:18 -070067 ll_entry_declare(struct driver_info, __name, driver_info)
Simon Glasscb43ac12020-10-03 11:31:41 -060068#endif
Simon Glass6494d702014-02-26 15:59:18 -070069
Simon Glass10778392014-10-01 19:57:21 -060070/* Declare a list of devices. The argument is a driver_info[] array */
Simon Glass20e442a2020-12-28 20:34:54 -070071#define U_BOOT_DRVINFOS(__name) \
Simon Glass10778392014-10-01 19:57:21 -060072 ll_entry_declare_list(struct driver_info, __name, driver_info)
73
Simon Glass3c140832020-10-03 09:25:20 -060074/**
75 * Get a pointer to a given device info given its name
76 *
Simon Glass8629d302020-12-28 20:34:55 -070077 * With the declaration U_BOOT_DRVINFO(name), DM_DRVINFO_GET(name) will return a
Simon Glass3c140832020-10-03 09:25:20 -060078 * pointer to the struct driver_info created by that declaration.
79 *
80 * if OF_PLATDATA is enabled, from this it is possible to use the @dev member of
81 * struct driver_info to find the device pointer itself.
82 *
Simon Glass3c140832020-10-03 09:25:20 -060083 * @__name: Driver name (C identifier, not a string. E.g. gpio7_at_ff7e0000)
84 * @return struct driver_info * to the driver that created the device
85 */
Simon Glass8629d302020-12-28 20:34:55 -070086#define DM_DRVINFO_GET(__name) \
Walter Lozanofed0f892020-06-25 01:10:11 -030087 ll_entry_get(struct driver_info, __name, driver_info)
88
Simon Glass6494d702014-02-26 15:59:18 -070089#endif