]>
Commit | Line | Data |
---|---|---|
83d290c5 | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
6aff3115 | 2 | /* |
bc11756d | 3 | * (C) Copyright 2002-2008 |
6aff3115 | 4 | * Wolfgang Denk, DENX Software Engineering, [email protected]. |
6aff3115 WD |
5 | */ |
6 | ||
9fb625ce | 7 | #include <env.h> |
371ee137 | 8 | #include <stdint.h> |
e3c52f2b | 9 | |
00c234f3 SB |
10 | /* |
11 | * Programs using the library must check which API is available, | |
12 | * that varies depending on the U-Boot version. | |
13 | * This can be changed in future | |
14 | */ | |
15 | #define FW_ENV_API_VERSION 1 | |
16 | ||
81974f44 | 17 | struct env_opts { |
371ee137 AF |
18 | #ifdef CONFIG_FILE |
19 | char *config_file; | |
20 | #endif | |
d40dbfb7 | 21 | char *lockname; |
371ee137 | 22 | }; |
07ce9440 | 23 | |
fd4e3280 AF |
24 | /** |
25 | * fw_printenv() - print one or several environment variables | |
26 | * | |
27 | * @argc: number of variables names to be printed, prints all if 0 | |
28 | * @argv: array of variable names to be printed, if argc != 0 | |
29 | * @value_only: do not repeat the variable name, print the bare value, | |
30 | * only one variable allowed with this option, argc must be 1 | |
31 | * @opts: encryption key, configuration file, defaults are used if NULL | |
32 | * | |
33 | * Description: | |
34 | * Uses fw_env_open, fw_getenv | |
35 | * | |
36 | * Return: | |
37 | * 0 on success, -1 on failure (modifies errno) | |
38 | */ | |
81974f44 | 39 | int fw_printenv(int argc, char *argv[], int value_only, struct env_opts *opts); |
fd4e3280 AF |
40 | |
41 | /** | |
382bee57 | 42 | * fw_env_set() - adds or removes one variable to the environment |
fd4e3280 AF |
43 | * |
44 | * @argc: number of strings in argv, argv[0] is variable name, | |
45 | * argc==1 means erase variable, argc > 1 means add a variable | |
46 | * @argv: argv[0] is variable name, argv[1..argc-1] are concatenated separated | |
47 | * by single blank and set as the new value of the variable | |
48 | * @opts: how to retrieve environment from flash, defaults are used if NULL | |
49 | * | |
50 | * Description: | |
33f0086c | 51 | * Uses fw_env_open, fw_env_write, fw_env_flush |
fd4e3280 AF |
52 | * |
53 | * Return: | |
54 | * 0 on success, -1 on failure (modifies errno) | |
55 | * | |
56 | * ERRORS: | |
57 | * EROFS - some variables ("ethaddr", "serial#") cannot be modified | |
58 | */ | |
382bee57 | 59 | int fw_env_set(int argc, char *argv[], struct env_opts *opts); |
fd4e3280 AF |
60 | |
61 | /** | |
62 | * fw_parse_script() - adds or removes multiple variables with a batch script | |
63 | * | |
64 | * @fname: batch script file name | |
65 | * @opts: encryption key, configuration file, defaults are used if NULL | |
66 | * | |
67 | * Description: | |
33f0086c | 68 | * Uses fw_env_open, fw_env_write, fw_env_flush |
fd4e3280 AF |
69 | * |
70 | * Return: | |
71 | * 0 success, -1 on failure (modifies errno) | |
72 | * | |
73 | * Script Syntax: | |
74 | * | |
75 | * key [ [space]+ value] | |
76 | * | |
77 | * lines starting with '#' treated as comment | |
78 | * | |
79 | * A variable without value will be deleted. Any number of spaces are allowed | |
80 | * between key and value. The value starts with the first non-space character | |
81 | * and ends with newline. No comments allowed on these lines. Spaces inside | |
82 | * the value are preserved verbatim. | |
83 | * | |
84 | * Script Example: | |
85 | * | |
86 | * netdev eth0 | |
87 | * | |
88 | * kernel_addr 400000 | |
89 | * | |
90 | * foo spaces are copied verbatim | |
91 | * | |
92 | * # delete variable bar | |
93 | * | |
94 | * bar | |
95 | */ | |
81974f44 | 96 | int fw_parse_script(char *fname, struct env_opts *opts); |
fd4e3280 AF |
97 | |
98 | ||
99 | /** | |
100 | * fw_env_open() - read enviroment from flash into RAM cache | |
101 | * | |
102 | * @opts: encryption key, configuration file, defaults are used if NULL | |
103 | * | |
104 | * Return: | |
105 | * 0 on success, -1 on failure (modifies errno) | |
106 | */ | |
81974f44 | 107 | int fw_env_open(struct env_opts *opts); |
fd4e3280 AF |
108 | |
109 | /** | |
110 | * fw_getenv() - lookup variable in the RAM cache | |
111 | * | |
112 | * @name: variable to be searched | |
113 | * Return: | |
114 | * pointer to start of value, NULL if not found | |
115 | */ | |
116 | char *fw_getenv(char *name); | |
117 | ||
118 | /** | |
119 | * fw_env_write() - modify a variable held in the RAM cache | |
120 | * | |
121 | * @name: variable | |
122 | * @value: delete variable if NULL, otherwise create or overwrite the variable | |
123 | * | |
124 | * This is called in sequence to update the environment in RAM without updating | |
125 | * the copy in flash after each set | |
126 | * | |
127 | * Return: | |
128 | * 0 on success, -1 on failure (modifies errno) | |
129 | * | |
130 | * ERRORS: | |
131 | * EROFS - some variables ("ethaddr", "serial#") cannot be modified | |
132 | */ | |
c3a23e8b | 133 | int fw_env_write(char *name, char *value); |
fd4e3280 AF |
134 | |
135 | /** | |
33f0086c SB |
136 | * fw_env_flush - write the environment from RAM cache back to flash |
137 | * | |
138 | * @opts: encryption key, configuration file, defaults are used if NULL | |
139 | * | |
140 | * Return: | |
141 | * 0 on success, -1 on failure (modifies errno) | |
142 | */ | |
143 | int fw_env_flush(struct env_opts *opts); | |
144 | ||
145 | /** | |
146 | * fw_env_close - free allocated structure and close env | |
fd4e3280 AF |
147 | * |
148 | * @opts: encryption key, configuration file, defaults are used if NULL | |
149 | * | |
150 | * Return: | |
151 | * 0 on success, -1 on failure (modifies errno) | |
152 | */ | |
81974f44 | 153 | int fw_env_close(struct env_opts *opts); |
6aff3115 | 154 | |
33f0086c | 155 | |
00c234f3 SB |
156 | /** |
157 | * fw_env_version - return the current version of the library | |
158 | * | |
159 | * Return: | |
160 | * version string of the library | |
161 | */ | |
162 | char *fw_env_version(void); |