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/gpio.h>  #include <stdio.h>  namespace android  {  struct gpio_device_t* gpio_device = NULL;  static void gpio_setVal(JNIEnv* env, jobject clazz, jint value) {  int val = value;    gpio_device->set_val(gpio_device, val);  }     static jint gpio_getVal(JNIEnv* env, jobject clazz) {  return 0;  }      static inline int gpio_device_open(const hw_module_t* module, struct gpio_device_t** device) {  return module->methods->open(module, GPIO_HARDWARE_MODULE_ID, (struct hw_device_t**)device);  }   static jboolean gpio_init(JNIEnv* env, jclass clazz) {  gpio_module_t* module;  if(hw_get_module(GPIO_HARDWARE_MODULE_ID, (const struct hw_module_t**)&module) == 0) {  if(gpio_device_open(&(module->common), &gpio_device) == 0){  return 0;  }    return -1;      }  return -1;        }    static const JNINativeMethod method_table[] = {  {"init_native", "()Z", (void*)gpio_init},  {"setVal_native", "(I)V", (void*)gpio_setVal},  {"getVal_native", "()I", (void*)gpio_getVal},  };   int register_android_server_GpioService(JNIEnv *env) {  return jniRegisterNativeMethods(env, "com/android/server/GpioService", method_table, NELEM(method_table));  }  };  
当中GPIO_HARDWARE_MODULE_ID是在hardware/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);

改动services/jni文件夹下的Android.mk文件:

在LOCAL_SRC_FILES增加:

com_android_server_GpioService.cpp \
编译JNI方法:

makeTARGET_PRODUCT=am335xevm_sk-j8OMAPES=4.x

假设成功,则生成libandroid_servers.so

out/target/product/am335xevm_sk/obj/lib/libandroid_servers.so  

JNI方法编译完毕后,就能够通过android硬件服务GpioService来调用JNI方法,以此来调用硬件抽象层訪问底层硬件。

更多相关文章

  1. 浅谈Java中Collections.sort对List排序的两种方法
  2. Python list sort方法的具体使用
  3. python list.sort()根据多个关键字排序的方法实现
  4. android上一些方法的区别和用法的注意事项
  5. android实现字体闪烁动画的方法
  6. Android(安卓)Wifi模块分析(三)
  7. Android中dispatchDraw分析
  8. Android四大基本组件介绍与生命周期
  9. Android(安卓)MediaPlayer 常用方法介绍

随机推荐

  1. 黑马程序员_Java基础_我的Day09学习笔记
  2. 如何在android中的recycler视图中显示第
  3. java.util.zip.ZipFile解压后被java占用
  4. java基础---多线程---java内存模型
  5. 纯Java开发的游戏引擎V0.5--DEMO2 -- 物
  6. Java如果提高反射效率
  7. MyBatis批量插入/更新Oracle。
  8. JavaMail学习五 创建邮件内容
  9. 循环-26. 求给定序列前N项和之四(15)
  10. AAC终结者Opus音频编码器的瑞士军刀,编译a