touch_modules_build.bzl 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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):
  4. module = struct(
  5. name = name,
  6. path = path,
  7. srcs = srcs,
  8. config_option = config_option
  9. )
  10. module_map[name] = module
  11. def _get_config_choices(map, options):
  12. choices = []
  13. for option in map:
  14. choices.extend(map[option].get(option in options,[]))
  15. return choices
  16. def _get_kernel_build_options(modules, config_options):
  17. all_options = {option: True for option in config_options}
  18. all_options = all_options | {module.config_option: True for module in modules if module.config_option}
  19. return all_options
  20. def _get_kernel_build_module_srcs(module, options, formatter):
  21. srcs = module.srcs
  22. print("-",module.name,",",module.config_option,",srcs =",srcs)
  23. module_path = "{}/".format(module.path) if module.path else ""
  24. return ["{}{}".format(module_path, formatter(src)) for src in srcs]
  25. def touch_module_entry(hdrs = []):
  26. module_map = {}
  27. def register(name, path = None, config_option = [], srcs = [], config_srcs = None, deps = None):
  28. _register_module_to_map(module_map, name, path, config_option, srcs)
  29. return struct(
  30. register = register,
  31. get = module_map.get,
  32. hdrs = hdrs
  33. )
  34. def define_target_variant_modules(target, variant, registry, modules, config_options = []):
  35. kernel_build = "{}_{}".format(target, variant)
  36. kernel_build_label = "//msm-kernel:{}".format(kernel_build)
  37. modules = [registry.get(module_name) for module_name in modules]
  38. options = _get_kernel_build_options(modules, config_options)
  39. build_print = lambda message : print("{}: {}".format(kernel_build, message))
  40. formatter = lambda s : s.replace("%b", kernel_build).replace("%t", target)
  41. headers = ["//msm-kernel:all_headers"] + registry.hdrs
  42. all_module_rules = []
  43. for module in modules:
  44. rule_name = "{}_{}".format(kernel_build, module.name)
  45. module_srcs = _get_kernel_build_module_srcs(module, options, formatter)
  46. if not module_srcs:
  47. continue
  48. ddk_submodule(
  49. name = rule_name,
  50. srcs = module_srcs,
  51. out = "{}.ko".format(module.name),
  52. deps = headers,
  53. local_defines = options.keys(),
  54. )
  55. all_module_rules.append(rule_name)
  56. ddk_module(
  57. name = "{}_touch_drivers".format(kernel_build),
  58. kernel_build = kernel_build_label,
  59. deps = all_module_rules,
  60. )
  61. copy_to_dist_dir(
  62. name = "{}_touch_drivers_dist".format(kernel_build),
  63. data = [":{}_touch_drivers".format(kernel_build)],
  64. dist_dir = "out/target/product/{}/dlkm/lib/modules".format(target),
  65. flat = True,
  66. wipe_dist_dir = False,
  67. allow_duplicate_filenames = False,
  68. mode_overrides = {"**/*": "644"},
  69. log = "info",
  70. )
  71. def define_consolidate_gki_modules(target, registry, modules, config_options = []):
  72. define_target_variant_modules(target, "gki", registry, modules, config_options)
  73. define_target_variant_modules(target, "consolidate", registry, modules, config_options)