secure.txt 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. * ARM Secure world bindings
  2. ARM CPUs with TrustZone support have two distinct address spaces,
  3. "Normal" and "Secure". Most devicetree consumers (including the Linux
  4. kernel) are not TrustZone aware and run entirely in either the Normal
  5. world or the Secure world. However some devicetree consumers are
  6. TrustZone aware and need to be able to determine whether devices are
  7. visible only in the Secure address space, only in the Normal address
  8. space, or visible in both. (One example of that situation would be a
  9. virtual machine which boots Secure firmware and wants to tell the
  10. firmware about the layout of the machine via devicetree.)
  11. The general principle of the naming scheme for Secure world bindings
  12. is that any property that needs a different value in the Secure world
  13. can be supported by prefixing the property name with "secure-". So for
  14. instance "secure-foo" would override "foo". For property names with
  15. a vendor prefix, the Secure variant of "vendor,foo" would be
  16. "vendor,secure-foo". If there is no "secure-" property then the Secure
  17. world value is the same as specified for the Normal world by the
  18. non-prefixed property. However, only the properties listed below may
  19. validly have "secure-" versions; this list will be enlarged on a
  20. case-by-case basis.
  21. Defining the bindings in this way means that a device tree which has
  22. been annotated to indicate the presence of Secure-only devices can
  23. still be processed unmodified by existing Non-secure software (and in
  24. particular by the kernel).
  25. Note that it is still valid for bindings intended for purely Secure
  26. world consumers (like kernels that run entirely in Secure) to simply
  27. describe the view of Secure world using the standard bindings. These
  28. secure- bindings only need to be used where both the Secure and Normal
  29. world views need to be described in a single device tree.
  30. Valid Secure world properties:
  31. - secure-status : specifies whether the device is present and usable
  32. in the secure world. The combination of this with "status" allows
  33. the various possible combinations of device visibility to be
  34. specified. If "secure-status" is not specified it defaults to the
  35. same value as "status"; if "status" is not specified either then
  36. both default to "okay". This means the following combinations are
  37. possible:
  38. /* Neither specified: default to visible in both S and NS */
  39. secure-status = "okay"; /* visible in both */
  40. status = "okay"; /* visible in both */
  41. status = "okay"; secure-status = "okay"; /* visible in both */
  42. secure-status = "disabled"; /* NS-only */
  43. status = "okay"; secure-status = "disabled"; /* NS-only */
  44. status = "disabled"; secure-status = "okay"; /* S-only */
  45. status = "disabled"; /* disabled in both */
  46. status = "disabled"; secure-status = "disabled"; /* disabled in both */