Changes in kernel/genarch/src/ofw/ofw_tree.c [63b5493:9d58539] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/genarch/src/ofw/ofw_tree.c
r63b5493 r9d58539 38 38 #include <genarch/ofw/ofw_tree.h> 39 39 #include <mm/slab.h> 40 #include <sysinfo/sysinfo.h> 40 41 #include <memstr.h> 41 42 #include <str.h> … … 65 66 const char *name) 66 67 { 67 size_t i; 68 69 for (i = 0; i < node->properties; i++) { 68 for (size_t i = 0; i < node->properties; i++) { 70 69 if (str_cmp(node->property[i].name, name) == 0) 71 70 return &node->property[i]; … … 104 103 const char *name) 105 104 { 106 ofw_tree_node_t *cur;107 108 105 /* 109 106 * Try to find the disambigued name. 110 107 */ 111 for ( cur = node->child; cur; cur = cur->peer) {108 for (ofw_tree_node_t *cur = node->child; cur; cur = cur->peer) { 112 109 if (str_cmp(cur->da_name, name) == 0) 113 110 return cur; … … 121 118 * are not always fully-qualified. 122 119 */ 123 for ( cur = node->child; cur; cur = cur->peer) {120 for (ofw_tree_node_t *cur = node->child; cur; cur = cur->peer) { 124 121 if (str_cmp(ofw_tree_node_name(cur), name) == 0) 125 122 return cur; … … 141 138 const char *dtype) 142 139 { 143 ofw_tree_node_t *cur; 144 145 for (cur = node->child; cur; cur = cur->peer) { 140 for (ofw_tree_node_t *cur = node->child; cur; cur = cur->peer) { 146 141 ofw_tree_property_t *prop = 147 142 ofw_tree_getprop(cur, "device_type"); … … 172 167 phandle handle) 173 168 { 174 ofw_tree_node_t *cur; 175 176 for (cur = root; cur; cur = cur->peer) { 169 for (ofw_tree_node_t *cur = root; cur; cur = cur->peer) { 177 170 if (cur->node_handle == handle) 178 171 return cur; 179 172 180 173 if (cur->child) { 181 ofw_tree_node_t *node 182 =ofw_tree_find_node_by_handle(cur->child, handle);174 ofw_tree_node_t *node = 175 ofw_tree_find_node_by_handle(cur->child, handle); 183 176 if (node) 184 177 return node; … … 201 194 const char *dtype) 202 195 { 203 ofw_tree_node_t *cur; 204 205 for (cur = node->peer; cur; cur = cur->peer) { 196 for (ofw_tree_node_t *cur = node->peer; cur; cur = cur->peer) { 206 197 ofw_tree_property_t *prop = 207 198 ofw_tree_getprop(cur, "device_type"); … … 229 220 const char *name) 230 221 { 231 ofw_tree_node_t *cur; 232 233 for (cur = node->peer; cur; cur = cur->peer) { 234 ofw_tree_property_t *prop 235 = ofw_tree_getprop(cur, "name"); 222 for (ofw_tree_node_t *cur = node->peer; cur; cur = cur->peer) { 223 ofw_tree_property_t *prop = 224 ofw_tree_getprop(cur, "name"); 236 225 237 226 if ((!prop) || (!prop->value)) … … 259 248 260 249 ofw_tree_node_t *node = ofw_root; 261 size_t i;262 250 size_t j; 263 251 264 for ( i = 1; (i < str_size(path)) && (node); i = j + 1) {252 for (size_t i = 1; (i < str_size(path)) && (node); i = j + 1) { 265 253 for (j = i; (j < str_size(path)) && (path[j] != '/'); j++); 266 254 … … 294 282 const char *dtype, ofw_tree_walker_t walker, void *arg) 295 283 { 296 ofw_tree_node_t *cur; 297 298 for (cur = node; cur; cur = cur->peer) { 284 for (ofw_tree_node_t *cur = node; cur; cur = cur->peer) { 299 285 ofw_tree_property_t *prop = 300 286 ofw_tree_getprop(cur, "device_type"); … … 334 320 } 335 321 336 /** Print OpenFirmware device subtree rooted in a node. 322 /** Get OpenFirmware node properties. 323 * 324 * @param item Sysinfo item (unused). 325 * @param size Size of the returned data. 326 * @param dry_run Do not get the data, just calculate the size. 327 * @param data OpenFirmware node. 328 * 329 * @return Data containing a serialized dump of all node 330 * properties. If the return value is not NULL, it 331 * should be freed in the context of the sysinfo request. 332 * 333 */ 334 static void *ofw_sysinfo_properties(struct sysinfo_item *item, size_t *size, 335 bool dry_run, void *data) 336 { 337 ofw_tree_node_t *node = (ofw_tree_node_t *) data; 338 339 /* Compute serialized data size */ 340 *size = 0; 341 for (size_t i = 0; i < node->properties; i++) 342 *size += str_size(node->property[i].name) + 1 + 343 sizeof(node->property[i].size) + node->property[i].size; 344 345 if (dry_run) 346 return NULL; 347 348 void *dump = malloc(*size, FRAME_ATOMIC); 349 if (dump == NULL) { 350 *size = 0; 351 return NULL; 352 } 353 354 /* Serialize the data */ 355 size_t pos = 0; 356 for (size_t i = 0; i < node->properties; i++) { 357 /* Property name */ 358 str_cpy(dump + pos, *size - pos, node->property[i].name); 359 pos += str_size(node->property[i].name) + 1; 360 361 /* Value size */ 362 memcpy(dump + pos, &node->property[i].size, 363 sizeof(node->property[i].size)); 364 pos += sizeof(node->property[i].size); 365 366 /* Value */ 367 memcpy(dump + pos, node->property[i].value, 368 node->property[i].size); 369 pos += node->property[i].size; 370 } 371 372 return ((void *) dump); 373 } 374 375 /** Map OpenFirmware device subtree rooted in a node into sysinfo. 337 376 * 338 377 * Child nodes are processed recursively and peer nodes are processed … … 343 382 * 344 383 */ 345 static void ofw_tree_node_ print(ofw_tree_node_t *node, const char *path)384 static void ofw_tree_node_sysinfo(ofw_tree_node_t *node, const char *path) 346 385 { 347 386 char *cur_path = (char *) malloc(PATH_MAX_LEN, 0); 348 ofw_tree_node_t *cur; 349 350 for (cur = node; cur; cur = cur->peer) { 351 if ((cur->parent) && (path)) { 352 snprintf(cur_path, PATH_MAX_LEN, "%s/%s", path, cur->da_name); 353 printf("%s\n", cur_path); 354 } else { 355 snprintf(cur_path, PATH_MAX_LEN, "%s", cur->da_name); 356 printf("/\n"); 357 } 387 388 for (ofw_tree_node_t *cur = node; cur; cur = cur->peer) { 389 if ((cur->parent) && (path)) 390 snprintf(cur_path, PATH_MAX_LEN, "%s.%s", path, cur->da_name); 391 else 392 snprintf(cur_path, PATH_MAX_LEN, "firmware.%s", cur->da_name); 393 394 sysinfo_set_item_gen_data(cur_path, NULL, ofw_sysinfo_properties, 395 (void *) cur); 358 396 359 397 if (cur->child) 360 ofw_tree_node_ print(cur->child, cur_path);398 ofw_tree_node_sysinfo(cur->child, cur_path); 361 399 } 362 400 … … 364 402 } 365 403 366 /** Print the structure of the OpenFirmware device tree. */367 void ofw_ tree_print(void)368 { 369 ofw_tree_node_ print(ofw_root, NULL);404 /** Map the OpenFirmware device tree into sysinfo. */ 405 void ofw_sysinfo_map(void) 406 { 407 ofw_tree_node_sysinfo(ofw_root, NULL); 370 408 } 371 409
Note:
See TracChangeset
for help on using the changeset viewer.