TQ210搭载Android4.0.3系统构建之ADC从驱动到HAL到JNI到应用程序(JNI篇)

   ADC的JNI层采用的方式与BEEP中JNI层采用的方式是一致的,采用Java+包名+类名+方法名,具体见BEEP的JNI层

   直接上源码

 adc_under_jni.c

#include <android/log.h>
#include <jni.h>
#include <hardware/hardware.h>
#include <hardware/adc_under_hal.h>

static struct adc_hw_device_t *adc_device=NULL;

#define true 1
#define false 0

static inline int adc_open(struct hw_module_t *module,struct adc_hw_device_t **device) //adc打开函数,获取到设备给adc_device
{
	int ret=module->methods->open(module,ADC_UNDER_ID,(struct hw_device_t **)device);
	if(ret!=0) __android_log_print(ANDROID_LOG_DEBUG,"msg", "can not open adc_open in jni.\n");
	return ret;
}


jint Java_com_under_adc_AdcActivity_adcRead(JNIEnv * env, jclass clazz) //读取adc的值
{
	if(adc_device==NULL) return false;
	return adc_device->read(adc_device);
}

jboolean Java_com_under_adc_AdcActivity_adcClose(JNIEnv * env, jclass clazz) //adc 关闭函数
{
 	if(adc_device==NULL) return false;
	return adc_device->common.close(&adc_device->common);
}

jboolean Java_com_under_adc_AdcActivity_adcInit(JNIEnv *env,jclass clazz)  //adc 初始胡函数,通过此函数获取到jni层的模块
{
	struct adc_hw_module_t *module;
	int ret=hw_get_module(ADC_UNDER_ID, (const struct hw_module_t **)&module); //通过ID获取到jni层的模块
	if(ret==0)
		{
			if(adc_open(&module->common,&adc_device)==0) return true;
		}
	__android_log_print(ANDROID_LOG_DEBUG, "msg","adcInit failed.\n");
	return false;
}





编译文件 Android.mk

 

LOCAL_PATH :=$(call my-dir)
include $(CLEAR_VARS)
LOCAL_PRELINK_MODULE :=false
LOCAL_SHARED_LIBRARIES :=libutils \
 libhardware
LOCAL_SRC_FILES  :=adc_under_jni.c
LOCAL_MODULE  :=libadcunders
LOCAL_MODULE_PATH :=$(LOCAL_PATH)
LOCAL_MODULE_TAGS :=optional
include $(BUILD_SHARED_LIBRARY)

 

 


 

 

posted on 2013-07-01 23:04  liangxinzhi  阅读(147)  评论(0编辑  收藏  举报