display_driver_build.bzl 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. load("//build/kernel/kleaf:kernel.bzl", "ddk_module", "ddk_submodule")
  2. load("//build/bazel_common_rules/dist:dist.bzl", "copy_to_dist_dir")
  3. def _register_module_to_map(module_map, name, path, config_option, srcs, config_srcs, deps, config_deps):
  4. processed_config_srcs = {}
  5. nested_config = {}
  6. processed_config_deps = {}
  7. for config_src_name in config_srcs:
  8. config_src = config_srcs[config_src_name]
  9. if type(config_src) == "list":
  10. processed_config_srcs[config_src_name] = {True: config_src}
  11. else:
  12. processed_config_srcs[config_src_name] = config_src
  13. if type(config_src) == "dict":
  14. nested_config = config_src
  15. for nested_src, nest_name in nested_config.items():
  16. if nested_src == True:
  17. processed_config_srcs[config_src_name] = {True: nest_name}
  18. else:
  19. processed_config_srcs[nested_src] = {True: nest_name}
  20. for config_deps_name in config_deps:
  21. config_dep = config_deps[config_deps_name]
  22. if type(config_dep) == "list":
  23. processed_config_deps[config_deps_name] = {True: config_dep}
  24. else:
  25. processed_config_deps[config_deps_name] = config_dep
  26. module = struct(
  27. name = name,
  28. path = path,
  29. srcs = srcs,
  30. config_srcs = processed_config_srcs,
  31. config_option = config_option,
  32. deps = deps,
  33. config_deps = processed_config_deps
  34. )
  35. module_map[name] = module
  36. def _get_config_choices(map, options):
  37. choices = []
  38. for option in map:
  39. choices.extend(map[option].get(option in options,[]))
  40. return choices
  41. def _get_kernel_build_options(modules, config_options):
  42. all_options = {option: True for option in config_options}
  43. all_options = all_options | {module.config_option: True for module in modules if module.config_option}
  44. return all_options
  45. def _get_kernel_build_module_srcs(module, options, formatter):
  46. srcs = module.srcs + _get_config_choices(module.config_srcs, options)
  47. module_path = "{}/".format(module.path) if module.path else ""
  48. return ["{}{}".format(module_path, formatter(src)) for src in srcs]
  49. def _get_kernel_build_module_deps(module, options, formatter):
  50. deps = module.deps + _get_config_choices(module.config_deps, options)
  51. return [formatter(dep) for dep in deps]
  52. def display_module_entry(hdrs = []):
  53. module_map = {}
  54. def register(name, path = None, config_option = None, srcs = [], config_srcs = {}, deps = [], config_deps = {}):
  55. _register_module_to_map(module_map, name, path, config_option, srcs, config_srcs, deps, config_deps)
  56. return struct(
  57. register = register,
  58. get = module_map.get,
  59. hdrs = hdrs,
  60. module_map = module_map
  61. )
  62. def define_target_variant_modules(target, variant, registry, modules, config_options = [], lunch_target=None):
  63. kernel_build_hdr = "{}_{}".format(target, variant)
  64. kernel_build_label = "//msm-kernel:{}".format(kernel_build_hdr)
  65. if lunch_target != None:
  66. kernel_build = "{}_{}_{}".format(target, variant, lunch_target)
  67. else:
  68. kernel_build = "{}_{}".format(target, variant)
  69. modules = [registry.get(module_name) for module_name in modules]
  70. options = _get_kernel_build_options(modules, config_options)
  71. build_print = lambda message : print("{}: {}".format(kernel_build, message))
  72. formatter = lambda s : s.replace("%b", kernel_build).replace("%t", target)
  73. formatter_hdr = lambda s : s.replace("%b", kernel_build_hdr).replace("%t", target)
  74. headers = ["//msm-kernel:all_headers"] + registry.hdrs
  75. all_module_rules = []
  76. for module in modules:
  77. rule_name = "{}_{}".format(kernel_build, module.name)
  78. module_srcs = _get_kernel_build_module_srcs(module, options, formatter)
  79. print(rule_name)
  80. if not module_srcs:
  81. continue
  82. ddk_submodule(
  83. name = rule_name,
  84. srcs = module_srcs,
  85. out = "{}.ko".format(module.name),
  86. deps = headers + _get_kernel_build_module_deps(module, options, formatter_hdr),
  87. local_defines = options.keys(),
  88. )
  89. all_module_rules.append(rule_name)
  90. ddk_module(
  91. name = "{}_display_drivers".format(kernel_build),
  92. kernel_build = kernel_build_label,
  93. deps = all_module_rules,
  94. )
  95. copy_to_dist_dir(
  96. name = "{}_display_drivers_dist".format(kernel_build),
  97. data = [":{}_display_drivers".format(kernel_build)],
  98. dist_dir = "out/target/product/{}/dlkm/lib/modules/".format(target),
  99. flat = True,
  100. wipe_dist_dir = False,
  101. allow_duplicate_filenames = False,
  102. mode_overrides = {"**/*": "644"},
  103. log = "info",
  104. )