qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v2 0/2] hw/arm/virt: dt: add kaslr-seed property
@ 2020-04-20 12:18 Jerome Forissier
  2020-04-20 12:18 ` [PATCH v2 1/2] hw/arm/virt: dt: move creation of /secure-chosen to create_fdt() Jerome Forissier
                   ` (2 more replies)
  0 siblings, 3 replies; 4+ messages in thread
From: Jerome Forissier @ 2020-04-20 12:18 UTC (permalink / raw)
  To: Peter Maydell, qemu-arm; +Cc: tee-dev, op-tee, Jerome Forissier, qemu-devel

This patchset creates the DT property /chosen/kaslr-seed which is used
by the OS for Address Space Layout Randomization. If the machine is
secure, a similar property is created under /secure-chosen.

Changes since v1:
 - Move creation of /secure-chosen to create_fdt()
 - Use qemu_guest_getrandom() instead of qcrypto_random_bytes()
 - Create kaslr-seed for the non-secure OS too

Jerome Forissier (2):
  hw/arm/virt: dt: move creation of /secure-chosen to create_fdt()
  hw/arm/virt: dt: add kaslr-seed property

 hw/arm/virt.c | 20 +++++++++++++++++++-
 1 file changed, 19 insertions(+), 1 deletion(-)

-- 
2.20.1



^ permalink raw reply	[flat|nested] 4+ messages in thread

* [PATCH v2 1/2] hw/arm/virt: dt: move creation of /secure-chosen to create_fdt()
  2020-04-20 12:18 [PATCH v2 0/2] hw/arm/virt: dt: add kaslr-seed property Jerome Forissier
@ 2020-04-20 12:18 ` Jerome Forissier
  2020-04-20 12:18 ` [PATCH v2 2/2] hw/arm/virt: dt: add kaslr-seed property Jerome Forissier
  2020-04-23 11:59 ` [PATCH v2 0/2] " Peter Maydell
  2 siblings, 0 replies; 4+ messages in thread
From: Jerome Forissier @ 2020-04-20 12:18 UTC (permalink / raw)
  To: Peter Maydell, qemu-arm; +Cc: tee-dev, op-tee, Jerome Forissier, qemu-devel

The /secure-chosen node is currently used only by create_uart(), but
this will change. Therefore move the creation of this node to
create_fdt().

Signed-off-by: Jerome Forissier <jerome@forissier.org>
---
 hw/arm/virt.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/hw/arm/virt.c b/hw/arm/virt.c
index 7dc96abf72c..c3073b7cf19 100644
--- a/hw/arm/virt.c
+++ b/hw/arm/virt.c
@@ -234,6 +234,10 @@ static void create_fdt(VirtMachineState *vms)
     /* /chosen must exist for load_dtb to fill in necessary properties later */
     qemu_fdt_add_subnode(fdt, "/chosen");
 
+    if (vms->secure) {
+        qemu_fdt_add_subnode(fdt, "/secure-chosen");
+    }
+
     /* Clock node, for the benefit of the UART. The kernel device tree
      * binding documentation claims the PL011 node clock properties are
      * optional but in practice if you omit them the kernel refuses to
@@ -761,7 +765,6 @@ static void create_uart(const VirtMachineState *vms, int uart,
         qemu_fdt_setprop_string(vms->fdt, nodename, "status", "disabled");
         qemu_fdt_setprop_string(vms->fdt, nodename, "secure-status", "okay");
 
-        qemu_fdt_add_subnode(vms->fdt, "/secure-chosen");
         qemu_fdt_setprop_string(vms->fdt, "/secure-chosen", "stdout-path",
                                 nodename);
     }
-- 
2.20.1



^ permalink raw reply related	[flat|nested] 4+ messages in thread

* [PATCH v2 2/2] hw/arm/virt: dt: add kaslr-seed property
  2020-04-20 12:18 [PATCH v2 0/2] hw/arm/virt: dt: add kaslr-seed property Jerome Forissier
  2020-04-20 12:18 ` [PATCH v2 1/2] hw/arm/virt: dt: move creation of /secure-chosen to create_fdt() Jerome Forissier
@ 2020-04-20 12:18 ` Jerome Forissier
  2020-04-23 11:59 ` [PATCH v2 0/2] " Peter Maydell
  2 siblings, 0 replies; 4+ messages in thread
From: Jerome Forissier @ 2020-04-20 12:18 UTC (permalink / raw)
  To: Peter Maydell, qemu-arm; +Cc: tee-dev, op-tee, Jerome Forissier, qemu-devel

Generate random seeds to be used by the non-secure and/or secure OSes
for ASLR. The seeds are 64-bit random values exported via the DT
properties /chosen/kaslr-seed [1] and /secure-chosen/kaslr-seed, the
latter being used by OP-TEE [2].

[1] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=e5bc0c37c97e1
[2] https://github.com/OP-TEE/optee_os/commit/ef262691fe0e

Signed-off-by: Jerome Forissier <jerome@forissier.org>
---
 hw/arm/virt.c | 15 +++++++++++++++
 1 file changed, 15 insertions(+)

diff --git a/hw/arm/virt.c b/hw/arm/virt.c
index c3073b7cf19..1b6f3971bf7 100644
--- a/hw/arm/virt.c
+++ b/hw/arm/virt.c
@@ -77,6 +77,7 @@
 #include "hw/acpi/generic_event_device.h"
 #include "hw/virtio/virtio-iommu.h"
 #include "hw/char/pl011.h"
+#include "qemu/guest-random.h"
 
 #define DEFINE_VIRT_MACHINE_LATEST(major, minor, latest) \
     static void virt_##major##_##minor##_class_init(ObjectClass *oc, \
@@ -213,6 +214,18 @@ static bool cpu_type_valid(const char *cpu)
     return false;
 }
 
+static void create_kaslr_seed(VirtMachineState *vms, const char *node)
+{
+    Error *err = NULL;
+    uint64_t seed;
+
+    if (qemu_guest_getrandom(&seed, sizeof(seed), &err)) {
+        error_free(err);
+        return;
+    }
+    qemu_fdt_setprop_u64(vms->fdt, node, "kaslr-seed", seed);
+}
+
 static void create_fdt(VirtMachineState *vms)
 {
     MachineState *ms = MACHINE(vms);
@@ -233,9 +246,11 @@ static void create_fdt(VirtMachineState *vms)
 
     /* /chosen must exist for load_dtb to fill in necessary properties later */
     qemu_fdt_add_subnode(fdt, "/chosen");
+    create_kaslr_seed(vms, "/chosen");
 
     if (vms->secure) {
         qemu_fdt_add_subnode(fdt, "/secure-chosen");
+        create_kaslr_seed(vms, "/secure-chosen");
     }
 
     /* Clock node, for the benefit of the UART. The kernel device tree
-- 
2.20.1



^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH v2 0/2] hw/arm/virt: dt: add kaslr-seed property
  2020-04-20 12:18 [PATCH v2 0/2] hw/arm/virt: dt: add kaslr-seed property Jerome Forissier
  2020-04-20 12:18 ` [PATCH v2 1/2] hw/arm/virt: dt: move creation of /secure-chosen to create_fdt() Jerome Forissier
  2020-04-20 12:18 ` [PATCH v2 2/2] hw/arm/virt: dt: add kaslr-seed property Jerome Forissier
@ 2020-04-23 11:59 ` Peter Maydell
  2 siblings, 0 replies; 4+ messages in thread
From: Peter Maydell @ 2020-04-23 11:59 UTC (permalink / raw)
  To: Jerome Forissier; +Cc: tee-dev, qemu-arm, QEMU Developers, op-tee

On Mon, 20 Apr 2020 at 13:20, Jerome Forissier <jerome@forissier.org> wrote:
>
> This patchset creates the DT property /chosen/kaslr-seed which is used
> by the OS for Address Space Layout Randomization. If the machine is
> secure, a similar property is created under /secure-chosen.
>
> Changes since v1:
>  - Move creation of /secure-chosen to create_fdt()
>  - Use qemu_guest_getrandom() instead of qcrypto_random_bytes()
>  - Create kaslr-seed for the non-secure OS too
>
> Jerome Forissier (2):
>   hw/arm/virt: dt: move creation of /secure-chosen to create_fdt()
>   hw/arm/virt: dt: add kaslr-seed property



Applied to target-arm.next, thanks.

-- PMM


^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2020-04-23 12:00 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-04-20 12:18 [PATCH v2 0/2] hw/arm/virt: dt: add kaslr-seed property Jerome Forissier
2020-04-20 12:18 ` [PATCH v2 1/2] hw/arm/virt: dt: move creation of /secure-chosen to create_fdt() Jerome Forissier
2020-04-20 12:18 ` [PATCH v2 2/2] hw/arm/virt: dt: add kaslr-seed property Jerome Forissier
2020-04-23 11:59 ` [PATCH v2 0/2] " Peter Maydell

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).