Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

settings.h 9.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319
  1. #ifndef _GPXE_SETTINGS_H
  2. #define _GPXE_SETTINGS_H
  3. /** @file
  4. *
  5. * Configuration settings
  6. *
  7. */
  8. #include <stdint.h>
  9. #include <gpxe/tables.h>
  10. #include <gpxe/list.h>
  11. #include <gpxe/refcnt.h>
  12. #include <gpxe/dhcpopts.h>
  13. struct settings;
  14. struct in_addr;
  15. union uuid;
  16. /** A setting */
  17. struct setting {
  18. /** Name
  19. *
  20. * This is the human-readable name for the setting.
  21. */
  22. const char *name;
  23. /** Description */
  24. const char *description;
  25. /** Setting type
  26. *
  27. * This identifies the type of setting (e.g. string, IPv4
  28. * address, etc.).
  29. */
  30. struct setting_type *type;
  31. /** DHCP option number, if applicable */
  32. unsigned int tag;
  33. };
  34. /** Declare a configuration setting */
  35. #define __setting __table ( struct setting, settings, 01 )
  36. /** Settings block operations */
  37. struct settings_operations {
  38. /** Store value of setting
  39. *
  40. * @v settings Settings block
  41. * @v setting Setting to store
  42. * @v data Setting data, or NULL to clear setting
  43. * @v len Length of setting data
  44. * @ret rc Return status code
  45. */
  46. int ( * store ) ( struct settings *settings, struct setting *setting,
  47. const void *data, size_t len );
  48. /** Fetch value of setting
  49. *
  50. * @v settings Settings block
  51. * @v setting Setting to fetch
  52. * @v data Buffer to fill with setting data
  53. * @v len Length of buffer
  54. * @ret len Length of setting data, or negative error
  55. *
  56. * The actual length of the setting will be returned even if
  57. * the buffer was too small.
  58. */
  59. int ( * fetch ) ( struct settings *settings, struct setting *setting,
  60. void *data, size_t len );
  61. };
  62. /** A settings block */
  63. struct settings {
  64. /** Reference counter */
  65. struct refcnt *refcnt;
  66. /** Name */
  67. const char *name;
  68. /** Tag magic
  69. *
  70. * This value will be ORed in to any numerical tags
  71. * constructed by parse_setting_name(), and can be used to
  72. * avoid e.g. attempting to retrieve the subnet mask from
  73. * SMBIOS, or the system UUID from DHCP.
  74. */
  75. unsigned int tag_magic;
  76. /** Parent settings block */
  77. struct settings *parent;
  78. /** Sibling settings blocks */
  79. struct list_head siblings;
  80. /** Child settings blocks */
  81. struct list_head children;
  82. /** Settings block operations */
  83. struct settings_operations *op;
  84. };
  85. /**
  86. * A setting type
  87. *
  88. * This represents a type of setting (e.g. string, IPv4 address,
  89. * etc.).
  90. */
  91. struct setting_type {
  92. /** Name
  93. *
  94. * This is the name exposed to the user (e.g. "string").
  95. */
  96. const char *name;
  97. /** Parse and set value of setting
  98. *
  99. * @v settings Settings block
  100. * @v setting Setting to store
  101. * @v value Formatted setting data
  102. * @ret rc Return status code
  103. */
  104. int ( * storef ) ( struct settings *settings, struct setting *setting,
  105. const char *value );
  106. /** Fetch and format value of setting
  107. *
  108. * @v settings Settings block
  109. * @v setting Setting to fetch
  110. * @v buf Buffer to contain formatted value
  111. * @v len Length of buffer
  112. * @ret len Length of formatted value, or negative error
  113. */
  114. int ( * fetchf ) ( struct settings *settings, struct setting *setting,
  115. char *buf, size_t len );
  116. };
  117. /** Declare a configuration setting type */
  118. #define __setting_type \
  119. __table ( struct setting_type, setting_types, 01 )
  120. /**
  121. * A settings applicator
  122. *
  123. */
  124. struct settings_applicator {
  125. /** Apply updated settings
  126. *
  127. * @ret rc Return status code
  128. */
  129. int ( * apply ) ( void );
  130. };
  131. /** Declare a settings applicator */
  132. #define __settings_applicator \
  133. __table ( struct settings_applicator, settings_applicators, 01 )
  134. /**
  135. * A simple settings block
  136. *
  137. */
  138. struct simple_settings {
  139. /** Settings block */
  140. struct settings settings;
  141. /** DHCP options */
  142. struct dhcp_options dhcpopts;
  143. };
  144. extern struct settings_operations simple_settings_operations;
  145. extern int simple_settings_store ( struct settings *settings,
  146. struct setting *setting,
  147. const void *data, size_t len );
  148. extern int simple_settings_fetch ( struct settings *settings,
  149. struct setting *setting,
  150. void *data, size_t len );
  151. extern int register_settings ( struct settings *settings,
  152. struct settings *parent );
  153. extern void unregister_settings ( struct settings *settings );
  154. extern int store_setting ( struct settings *settings, struct setting *setting,
  155. const void *data, size_t len );
  156. extern int fetch_setting ( struct settings *settings, struct setting *setting,
  157. void *data, size_t len );
  158. extern int fetch_setting_len ( struct settings *settings,
  159. struct setting *setting );
  160. extern int fetch_string_setting ( struct settings *settings,
  161. struct setting *setting,
  162. char *data, size_t len );
  163. extern int fetch_string_setting_copy ( struct settings *settings,
  164. struct setting *setting,
  165. char **data );
  166. extern int fetch_ipv4_setting ( struct settings *settings,
  167. struct setting *setting, struct in_addr *inp );
  168. extern int fetch_int_setting ( struct settings *settings,
  169. struct setting *setting, long *value );
  170. extern int fetch_uint_setting ( struct settings *settings,
  171. struct setting *setting,
  172. unsigned long *value );
  173. extern long fetch_intz_setting ( struct settings *settings,
  174. struct setting *setting );
  175. extern unsigned long fetch_uintz_setting ( struct settings *settings,
  176. struct setting *setting );
  177. extern int fetch_uuid_setting ( struct settings *settings,
  178. struct setting *setting, union uuid *uuid );
  179. extern int setting_cmp ( struct setting *a, struct setting *b );
  180. extern struct settings * find_child_settings ( struct settings *parent,
  181. const char *name );
  182. extern struct settings * find_settings ( const char *name );
  183. extern int storef_setting ( struct settings *settings,
  184. struct setting *setting,
  185. const char *value );
  186. extern int storef_named_setting ( const char *name, const char *value );
  187. extern int fetchf_named_setting ( const char *name, char *buf, size_t len );
  188. extern struct setting_type setting_type_string __setting_type;
  189. extern struct setting_type setting_type_ipv4 __setting_type;
  190. extern struct setting_type setting_type_int8 __setting_type;
  191. extern struct setting_type setting_type_int16 __setting_type;
  192. extern struct setting_type setting_type_int32 __setting_type;
  193. extern struct setting_type setting_type_uint8 __setting_type;
  194. extern struct setting_type setting_type_uint16 __setting_type;
  195. extern struct setting_type setting_type_uint32 __setting_type;
  196. extern struct setting_type setting_type_hex __setting_type;
  197. extern struct setting_type setting_type_uuid __setting_type;
  198. extern struct setting ip_setting __setting;
  199. extern struct setting netmask_setting __setting;
  200. extern struct setting gateway_setting __setting;
  201. extern struct setting dns_setting __setting;
  202. extern struct setting domain_setting __setting;
  203. extern struct setting hostname_setting __setting;
  204. extern struct setting filename_setting __setting;
  205. extern struct setting root_path_setting __setting;
  206. extern struct setting username_setting __setting;
  207. extern struct setting password_setting __setting;
  208. extern struct setting priority_setting __setting;
  209. extern struct setting uuid_setting __setting;
  210. extern struct setting next_server_setting __setting;
  211. extern struct setting mac_setting __setting;
  212. extern struct setting user_class_setting __setting;
  213. /**
  214. * Initialise a settings block
  215. *
  216. * @v settings Settings block
  217. * @v op Settings block operations
  218. * @v refcnt Containing object reference counter, or NULL
  219. * @v name Settings block name
  220. * @v tag_magic Tag magic
  221. */
  222. static inline void settings_init ( struct settings *settings,
  223. struct settings_operations *op,
  224. struct refcnt *refcnt,
  225. const char *name,
  226. unsigned int tag_magic ) {
  227. INIT_LIST_HEAD ( &settings->siblings );
  228. INIT_LIST_HEAD ( &settings->children );
  229. settings->op = op;
  230. settings->refcnt = refcnt;
  231. settings->name = name;
  232. settings->tag_magic = tag_magic;
  233. }
  234. /**
  235. * Initialise a settings block
  236. *
  237. * @v simple Simple settings block
  238. * @v refcnt Containing object reference counter, or NULL
  239. * @v name Settings block name
  240. */
  241. static inline void simple_settings_init ( struct simple_settings *simple,
  242. struct refcnt *refcnt,
  243. const char *name ) {
  244. settings_init ( &simple->settings, &simple_settings_operations,
  245. refcnt, name, 0 );
  246. }
  247. /**
  248. * Delete setting
  249. *
  250. * @v settings Settings block
  251. * @v setting Setting to delete
  252. * @ret rc Return status code
  253. */
  254. static inline int delete_setting ( struct settings *settings,
  255. struct setting *setting ) {
  256. return store_setting ( settings, setting, NULL, 0 );
  257. }
  258. /**
  259. * Fetch and format value of setting
  260. *
  261. * @v settings Settings block, or NULL to search all blocks
  262. * @v setting Setting to fetch
  263. * @v type Settings type
  264. * @v buf Buffer to contain formatted value
  265. * @v len Length of buffer
  266. * @ret len Length of formatted value, or negative error
  267. */
  268. static inline int fetchf_setting ( struct settings *settings,
  269. struct setting *setting,
  270. char *buf, size_t len ) {
  271. return setting->type->fetchf ( settings, setting, buf, len );
  272. }
  273. /**
  274. * Delete named setting
  275. *
  276. * @v name Name of setting
  277. * @ret rc Return status code
  278. */
  279. static inline int delete_named_setting ( const char *name ) {
  280. return storef_named_setting ( name, NULL );
  281. }
  282. /**
  283. * Check existence of setting
  284. *
  285. * @v settings Settings block, or NULL to search all blocks
  286. * @v setting Setting to fetch
  287. * @ret exists Setting exists
  288. */
  289. static inline int setting_exists ( struct settings *settings,
  290. struct setting *setting ) {
  291. return ( fetch_setting_len ( settings, setting ) >= 0 );
  292. }
  293. #endif /* _GPXE_SETTINGS_H */