首页 > 移动平台 > 详细

Android 从硬件到应用:一步一步向上爬 4 -- 使用 JNI 方法调硬件驱动

时间:2014-12-15 23:38:27      阅读:494      评论:0      收藏:0      [点我收藏+]

Android下,java应用程序通过JNI方法调用硬件抽象层模块,在Android 从硬件到应用:一步一步向上爬 3 -- 硬件抽象层访问硬件驱动

中我们已经编译好了硬件抽象层模块,下面就要开始为HAL层编写JNI方法,为上层提供服务。

cd到frameworks/base/services/jni目录中,新建一个com_android_server_GpioService.cpp文件:

#include "jni.h"  
#include "JNIHelp.h"  
#include "android_runtime/AndroidRuntime.h"  
#include <utils/misc.h>  
#include <utils/Log.h>  
#include <hardware/hardware.h>  
#include <hardware/android_gpio.h>  
#include <stdio.h>  
namespace android  
{  
	struct android_gpio_device_t* android_gpio_device = NULL;  

	static void android_gpio_setVal(JNIEnv* env, jobject clazz, jint value) 
	{  
		int val = value;    
		android_gpio_device->set_val(android_gpio_device, val);  
	}  
   
	static jint android_gpio_getVal(JNIEnv* env, jobject clazz) 
	{  
		return 0;  
	}  
	    
	static inline int android_gpio_device_open(const hw_module_t* module, struct android_gpio_device_t** device) 
	{  
		return module->methods->open(module, ANDROID_GPIO_HARDWARE_MODULE_ID, (struct hw_device_t**)device);  
	}  
	 
	static jboolean android_gpio_init(JNIEnv* env, jclass clazz) 
	{  
		android_gpio_module_t* module;  
		if(hw_get_module(ANDROID_GPIO_HARDWARE_MODULE_ID, (const struct hw_module_t**)&module) == 0) 
		{  
			if(android_gpio_device_open(&(module->common), &android_gpio_device) == 0)
			{  
				return 0;  
			}    
			return -1;  
	    	}  
		return -1;        
	}  
	  
	static const JNINativeMethod method_table[] = 
	{  
		{"init_native", "()Z", (void*)android_gpio_init},  
		{"setVal_native", "(I)V", (void*)android_gpio_setVal},  
		{"getVal_native", "()I", (void*)android_gpio_getVal},  
	};  
	 
	int register_android_server_GpioService(JNIEnv *env) {  
		return jniRegisterNativeMethods(env, "com/android/server/GpioService", method_table, NELEM(method_table));  
	}  
};  
其中ANDROID_GPIO_HARDWARE_MODULE_ID是在hardware/android_gpio.h中定义的,初始化时通过hw_get_module方法加载硬件层模块。 修改当前目录下的onload.cpp:

在namespace android中加入函数声明:

int register_android_server_GpioService(JNIEnv* env);
在JNI_Onload中加入函数调用:

register_android_server_GpioService(env);
修改frameworks/base/core/jni下的AndroidRuntime.cpp,在namespace android中加入声明:

extern int register_android_server_GpioService(JNIEnv* env);

修改当前目录下的Android.mk文件:

在LOCAL_SRC_FILES加入:

com_android_server_GpioService.cpp \
编译JNI方法:

mmm frameworks/base/services/jni
如果提示缺少libandroid_runtime.so、libsystem_server.so、libandroid_servers.so,执行:

make libandroid_runtime

make libsystem_server
make libandroid_servers
JNI方法编译完成后,就可以通过android硬件服务GpioService来调用JNI方法,以此来调用硬件抽象层访问底层硬件。

Android 从硬件到应用:一步一步向上爬 4 -- 使用 JNI 方法调硬件驱动

原文:http://blog.csdn.net/wu20093346/article/details/41871663

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!