From: Simon Glass Date: Mon, 15 Mar 2021 04:25:13 +0000 (+1300) Subject: linker_lists: Allow use in data structures X-Git-Tag: v2025.01-rc5-pxa1908~1941^2~4^2~72 X-Git-Url: http://git.dujemihanovic.xyz/%22http:/www.sics.se/static/git-favicon.png?a=commitdiff_plain;h=851144350b6ff1d4982b9af2f9b0fe48aed24b3c;p=u-boot.git linker_lists: Allow use in data structures At present linker lists are designed for use in code. They make use of statements within expressions ({...}), for example. It is possible to generate a reference to a linker_list entry that can be used in data structures, where such features are not permitted. It requires that the reference first be declared as extern. In other words the existing macro needs to be split into two parts. Add new macros to support this. Signed-off-by: Simon Glass Signed-off-by: Simon Glass --- diff --git a/include/linker_lists.h b/include/linker_lists.h index fd98ecd297..0ca30da417 100644 --- a/include/linker_lists.h +++ b/include/linker_lists.h @@ -211,6 +211,18 @@ _ll_result; \ }) +/** + * ll_entry_ref() - Get a reference to a linker-generated array entry + * + * Once ll_entry_decl() has been used to declare the reference, this macro + * allows the entry to be accessed. + * + * This is like ll_entry_get(), but without the extra code, so it is suitable + * for putting into data structures. + */ +#define ll_entry_ref(_type, _name, _list) \ + ((_type *)&_u_boot_list_2_##_list##_2_##_name) + /** * ll_start() - Point to first entry of first linker-generated array * @_type: Data type of the entry