Skip to content

Commit

Permalink
dt: Add global option to set phandle start offset
Browse files Browse the repository at this point in the history
If anyone outside of QEMU wants to mess with a QEMU generated device tree,
he needs to know which range phandles are valid in. So let's expose a
machine option that an external program can use to set the start allocate
id for phandles in QEMU.

Signed-off-by: Alexander Graf <[email protected]>
  • Loading branch information
agraf committed Jun 23, 2012
1 parent 3627757 commit 4b1b1c8
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 1 deletion.
28 changes: 27 additions & 1 deletion device_tree.c
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@
#include "qemu-common.h"
#include "device_tree.h"
#include "hw/loader.h"
#include "qemu-option.h"
#include "qemu-config.h"

#include <libfdt.h>

Expand Down Expand Up @@ -200,7 +202,31 @@ int qemu_devtree_setprop_phandle(void *fdt, const char *node_path,

uint32_t qemu_devtree_alloc_phandle(void *fdt)
{
static int phandle = 0x8000;
static int phandle = 0x0;

/*
* We need to find out if the user gave us special instruction at
* which phandle id to start allocting phandles.
*/
if (!phandle) {
QemuOpts *machine_opts;
machine_opts = qemu_opts_find(qemu_find_opts("machine"), 0);
if (machine_opts) {
const char *phandle_start;
phandle_start = qemu_opt_get(machine_opts, "phandle_start");
if (phandle_start) {
phandle = strtoul(phandle_start, NULL, 0);
}
}
}

if (!phandle) {
/*
* None or invalid phandle given on the command line, so fall back to
* default starting point.
*/
phandle = 0x8000;
}

return phandle++;
}
Expand Down
4 changes: 4 additions & 0 deletions qemu-config.c
Original file line number Diff line number Diff line change
Expand Up @@ -587,6 +587,10 @@ static QemuOptsList qemu_machine_opts = {
.name = "dumpdtb",
.type = QEMU_OPT_STRING,
.help = "Dump current dtb to a file and quit",
}, {
.name = "phandle_start",
.type = QEMU_OPT_STRING,
.help = "The first phandle ID we may generate dynamically",
},
{ /* End of list */ }
},
Expand Down

0 comments on commit 4b1b1c8

Please sign in to comment.