tree: 4341deb4208cd56f48598d1fa01fef9329a8a9d6 [path history] [tgz]
  1. BUILD.zircon.gn
  2. OWNERS
  3. README.md
  4. alias_workaround.cc
  5. alias_workaround.h
  6. alias_workaround_test.cc
  7. c_ulib_header_output.cc
  8. c_ulib_header_output_test.cc
  9. category_output.cc
  10. category_output_test.cc
  11. cdecl_output.cc
  12. cdecl_output_test.cc
  13. fidl_to_h.py
  14. go_syscalls_output.cc
  15. go_syscalls_output_test.cc
  16. go_vdso_output.cc
  17. go_vdso_output_test.cc
  18. golden-test
  19. golden.txt
  20. json_output.cc
  21. json_output_test.cc
  22. kernel_wrappers_output.cc
  23. kernel_wrappers_output_test.cc
  24. ktrace_output.cc
  25. ktrace_output_test.cc
  26. macros.h
  27. main.cc
  28. output_util.cc
  29. output_util.h
  30. output_util_test.cc
  31. outputs.h
  32. ownership_annotation_test.cc
  33. runtests
  34. rust_output.cc
  35. rust_output_test.cc
  36. string_util.cc
  37. string_util.h
  38. string_util_test.cc
  39. syscall_library.cc
  40. syscall_library.h
  41. syscall_library_test.cc
  42. syscall_numbers_output.cc
  43. syscall_numbers_output_test.cc
  44. test.h
  45. test_aliases.test.fidl
  46. test_go_nonblocking.test.fidl
  47. test_go_reserved_words.test.fidl
  48. test_kernel_cases.test.fidl
  49. test_kernelwrappers.test.fidl
  50. test_main.cc
  51. test_no_methods.test.fidl
  52. test_one_protocol_one_method.test.fidl
  53. test_one_protocol_two_methods.test.fidl
  54. test_one_protocol_two_methods_with_internal.test.fidl
  55. test_out_voidptr.test.fidl
  56. test_ownership_annotations.test.fidl
  57. test_pointers_and_vectors.test.fidl
  58. test_rights_specs.test.fidl
  59. test_rust_selection.test.fidl
  60. test_selection.test.fidl
  61. test_ulib_bits.test.fidl
  62. test_ulib_enums.test.fidl
  63. test_ulib_tables.test.fidl
  64. test_ulib_type_aliases.test.fidl
  65. test_various_categories.test.fidl
  66. test_vdsowrappers.test.fidl
  67. writer.cc
  68. writer.h
  69. writer_test.cc
zircon/tools/kazoo/README.md

Kazoo: Backend for fidlc for syscall definitions

Summary

kazoo is a host-side tool that operates as a backend for fidlc. In particular, Kazoo is used to process the definitions of kernel syscalls, and output various formats used by the kernel, user space, and other tools. See kazoo -h for a complete list of the output formats.

fidlc is run first to parse and interpret .fidl files, and it outputs a JSON IR representation. kazoo then processes the JSON IR.

FIDL syntax

In order to use the base FIDL syntax to express syscalls, some experimental syntax and style extensions are used. A possibly-incomplete outline of these as compared with standard FIDL syntax includes:

  • The attribute [Transport="Syscall"] must be applied to all protocols that are part of the syscall interface.

  • All .fidl files must be part of library zx (for syscalls) or library zxio.

  • Type aliases used to impart meaning. alias_workarounds.fidl includes various aliases that expand to something similar to the correct type, however Kazoo treats these specially. For example, mutable_string is used to indicate that the type is a string, but that should be treated as mutable (generally for a string that's both input and output).

  • Doc comments of the form /// Rights: ... are used by the Kazoo JSON generator, and are propagated to the documentation update script.

  • Attributes of the form [vdsocall], [const], etc. correspond to the previous similar definitions in abigen.

  • Some structs are defined in the current .fidl files, however, they're not used to generate the real Zircon headers yet. Similarly for enums, bits, etc. Only protocols are used to define the function syscall interface.

Testing

There are unittests in kazoo-test which are in the source tree next to the rest of the implementation.

These can be run using ./runtests which will also run fidlc and kazoo and generate all the outputs into /tmp for inspection. It should be run with a cwd of //zircon/tools/kazoo as ./runtests.

There is also a “golden”-style run, which compares the output of running kazoo on the current real syscalls, and diffs vs. //zircon/tools/kazoo/golden.txt. Instructions will be printed on how to update this if output changes.