HAL module执行过程分析

转自:http://blog.chinaunix.net/uid-722885-id-124922.html


HAL module执行过程分析

1.其初始化过程如下:

System.loadLibrary("led_runtime")->JNI_OnLoad()->registerMethods()-> ->env->RegisterNatives(clazz,gMethods,sizeof(gMethods)/sizeof(gMethods[0]));

 

onCreate() ->led_srv = new LedService() ->_init()->led_init() -> hw_get_module(LED_HARDWARE_MODULE_ID, (const hw_module_t**)&module) ->

 led_control_open(&module->common,&sLedDevice)-> module->methods->open(module,LED_HARDWARE_MODULE_ID,(struct hw_device_t**)device) -> led_device_open()

如此就完成了app到底层的初始化工作。

2.接下来看一下hw_get_module()函数。

hw_get_module()->property_get(variant_keys[i],prop,NULL)->__system_property_get(key, value) ->__system_property_find(const char *name)-> __system_property_read(pi, 0, value)-> load(id, prop, &hmi)->snprintf(path,sizeof(path), "%s/%s.%s.so", HAL_LIBRARY_PATH, id, variant)-> handle = dlopen(path, RTLD_NOW)-> const char *sym = HAL_MODULE_INFO_SYM_AS_STR; hmi = (const struct hw_module_t *)dlsym(handle, sym)

3. 最后我们看一下property_get(variant_keys[i],prop,NULL)

这个其实就是获取ro.hardware属性,我们关心的就是这个值是什么。在system/core/init/init.c文件中的main函数中有这么一句:property_set("ro.hardware", hardware);无疑ro.hardware的值就是hardware中的内容了。我们再找一下hardware赋的什么值,就ok了。其实就是在这个函数中完成的get_hardware_name()。

open("/proc/cpuinfo", O_RDONLY)

hw = strstr(data, "\nHardware")

while (*x && !isspace(*x))

   hardware[n++] = tolower(*x);

   x++;

   if (n == 31) break;

 }

Ok,我们看到了,它是从/proc/cpuinfo中读出来的。我们再打开cpuinfo文件看一下:Hardware: Goldfish。好了,我们确定了property_get()得到的是goldfish,那么snprintf(path, sizeof(path), "%s/%s.%s.so", HAL_LIBRARY_PATH, id, variant)构造出来的path就是/system/lib/hw/led.goldfish.so。终于找到咱们的so文件了。



你可能感兴趣的:(struct,Module,null,System,Path,library)