很多时候我们需要从 HAL 层(Hardware Abstract Layer)传一个标志给 kernel 层。一般这种传递是不能直接通过定义全局变量来实现的。

此时可以通过读写文件来实现该标志。

譬如我们有这样一个需求,在录像过程中去掉持续对焦功能,而录像预览时开启持续对焦功能。

在 HAL 层中有开始录像和停止录像的接口。

/trunk/ALPS.JB3.TDD.MP.V2_TD_xxx/mediatek/platform/mt6572/hardware/camera/hal/client/CamClient/Record/RecordClient.cpp 文件中

在 /sys/devices/platform/lens_actuator/ 目录下创建一个 VideoRec_Flag 这样的文件,在开始录像时将该文件中写入一个字节的值为1,而在停止录像时将该文件中写入一个字节的值为0。

 bool
RecordClient::
startRecording()
{
bool ret = false;
//
MY_LOGD("+");
//
Mutex::Autolock _l(mModuleMtx);
//
#if 1
int flag[]= {}; FILE *fd = NULL;
fd = fopen("/sys/devices/platform/lens_actuator/VideoRec_Flag","w"); if(fd == NULL)
MY_LOGD("BBN_TestMode open failed");
else{
MY_LOGD("BBN_TestMode open ok");
fwrite(&flag,,,fd);
fclose(fd);
}
#endif if(isEnabledState())
{
MY_LOGE("Recording has been started");
goto lbExit;
}
//
MY_LOGD("+ current mIsRecStarted=%d", mIsRecStarted);
::android_atomic_write(, &mIsRecStarted);
//
mpParamsMgr->getVideoSize(&mi4RecWidth, &mi4RecHeight);
MY_LOGD("+ record: WxH=%dx%d, format(%s)", mi4RecWidth, mi4RecHeight, MtkCameraParameters::PIXEL_FORMAT_YUV420I);//CameraParameters::PIXEL_FORMAT_YUV420P);
//
mTimeStart = systemTime();
mTimeEnd = mTimeStart;
mFrameCount = ;
mLastTimeStamp = ;
//
ret = onStateChanged();
//
lbExit:
//
MY_LOGD("-");
//
return ret;
} /******************************************************************************
*
******************************************************************************/
bool
RecordClient::
stopRecording()
{
bool ret = false;
status_t status = NO_ERROR;
//
MY_LOGD("+");
//
#if 1
int flag[]= {}; FILE *fd = NULL;
fd = fopen("/sys/devices/platform/lens_actuator/VideoRec_Flag","w"); if(fd == NULL)
MY_LOGD("BBN_TestMode open failed");
else{
MY_LOGD("BBN_TestMode open ok");
fwrite(&flag,,,fd);
fclose(fd);
}
#endif Mutex::Autolock _l(mModuleMtx);
//
if(!isEnabledState())
{
MY_LOGE("Recording has been stopped");
goto lbExit;
}
//
MY_LOGD("getThreadId(%d), getStrongCount(%d), this(%p)", getThreadId(), getStrongCount(), this);
//
MY_LOGD("+ current mIsRecStarted=%d", mIsRecStarted);
::android_atomic_write(, &mIsRecStarted);
//
ret = onStateChanged();
//
mpImgBufQueue->pauseProcessor();
//
lbExit:
//
MY_LOGD("-");
//
return ret;
}

在/trunk/ALPS.JB3.TDD.MP.V2_TD_xxx/mediatek/custom/common/kernel/imgsensor/ov5645_mipi_yuv/ov5645mipiyuv_Sensor.c 文件中

在 OV5645_FOCUS_OVT_AFC_Constant_Focus() 函数中读取之前VideoRec_Flag那个文件中的值,若为1,则进行持续对焦,否则,放弃持续对焦。在驱动文件中是通过写寄存器来实现的。

 static void OV5645_FOCUS_OVT_AFC_Constant_Focus(void)
{
printk("FM50AF_VideoRec_Flag=%d \n",FM50AF_VideoRec_Flag); if(FM50AF_VideoRec_Flag)
{
OV5645MIPI_write_cmos_sensor(0x3023,0x01);
OV5645MIPI_write_cmos_sensor(0x3022,0x06);
}
else{
OV5645MIPI_write_cmos_sensor(0x3023,0x01);
OV5645MIPI_write_cmos_sensor(0x3022,0x80);
mDELAY();
OV5645MIPI_write_cmos_sensor(0x3024,0x00);
OV5645MIPI_write_cmos_sensor(0x3023,0x01);
OV5645MIPI_write_cmos_sensor(0x3022,0x04);
}
}

具体的读取方式如下:

 int FM50AF_VideoRec_Flag;  

 EXPORT_SYMBOL(FM50AF_VideoRec_Flag);  

 static ssize_t show_VideoRec_Flag(struct device *dev,struct device_attribute *attr, char *buf)
{
// xlog_printk(ANDROID_LOG_DEBUG, "show_VideoRec_Flag test", "[Battery] show_BN_TestMode : %x\n", g_BN_TestMode); printk("show_VideoRec_Flag FM50AF_VideoRec_Flag=%d \n",FM50AF_VideoRec_Flag);
return sprintf(buf, "%u\n", FM50AF_VideoRec_Flag); }
static ssize_t store_VideoRec_Flag(struct device *dev,struct device_attribute *attr, const char *buf, size_t size)
{
char *pvalue = NULL;
unsigned int reg_BN_TestMode = ;
printk( "store_VideoRec_Flag \n");
if(buf != NULL && size != )
{
printk("store_VideoRec_Flag test111", "[Battery] buf is =%s , size is =%d \n",buf,size);
printk("store_VideoRec_Flag buf= %d ,size=%d \n", *buf,size);
// reg_BN_TestMode = simple_strtoul(buf,&pvalue,10);
FM50AF_VideoRec_Flag=*buf;
}
// return size;
return FM50AF_VideoRec_Flag;
}
static DEVICE_ATTR(VideoRec_Flag, , show_VideoRec_Flag, store_VideoRec_Flag);

这其中涉及到一些驱动文件中读写文件的格式的写法需要注意下。

至此,就可以实现该需求了。

如何在 kernel 和 hal 层读取同一个标志的更多相关文章

  1. Android HAL层与Linux Kernel层驱动开发简介

    近日稍微对Android中的驱动开发做了一些简要的了解. HAL:Hardware Abstract Layer 硬件抽象层,由于Linux Kernel需要遵循GPL开源协议,硬件厂商为了保护自己硬 ...

  2. 高通HAL层之Sensor HAL

    高通的HAL层其实分为两种,一种是直接从kernel这边报数据上来的,由sensor HAL层来监听,另一种是走ADSP的模式,HAL层是通过qmi的形式进行监听的: 走ADSP架构的可以看下面的博客 ...

  3. Android Hal层简要分析

    Android Hal层简要分析 Android Hal层(即 Hardware Abstraction Layer)是Google开发的Android系统里上层应用对底层硬件操作屏蔽的一个软件层次, ...

  4. 【Android】Sensor框架HAL层解读

    Android sensor构建 Android4.1 系统内置对传感器的支持达13种,他们分别是:加速度传感器(accelerometer).磁力传感器(magnetic field).方向传感器( ...

  5. 〖Android〗OK6410a的Android HAL层代码编写笔记

    一.编写LED灯的Linux驱动程序代码 之所以使用存在HAL层,是为了保护对硬件驱动过程的逻辑与原理: 所以,残留在Linux驱动层的代码,只保留了基本的读写操作,而不含有关键的逻辑思维: 1. l ...

  6. Android native进程间通信实例-binder篇之——HAL层访问JAVA层的服务

    有一天在群里聊天的时候,有人提出一个问题,怎样才能做到HAL层访问JAVA层的接口?刚好我不会,所以做了一点研究. 之前的文章末尾部分说过了service call 可以用来调试系统的binder服务 ...

  7. ZT Android4.2关于bluetooth在HAL层的分析(1)

    我的电子杂烩饭 http://blog.sina.com.cn/wuchuchu2012 [订阅][手机订阅] 首页 博文目录 图片 关于我 正文 字体大小:大 中 小 Android4.2关于blu ...

  8. 读取properties文件------servletcontext及dao层读取

    用servletcontext读取properties文件-------1) 重点在于:InputStream in=this.getServletContext().getResourceAsStr ...

  9. 51全志R58平台Android4.4下Camera的HAL层修改

    51全志R58平台Android4.4下Camera的HAL层修改 2018/11/7 15:20 版本:V1.0 开发板:SC5806 1.系统编译: (略) 2.全志R58平台Android4.4 ...

随机推荐

  1. 【转】Android中处理崩溃异常

    大家都知道,现在安装Android系统的手机版本和设备千差万别,在模拟器上运行良好的程序安装到某款手机上说不定就出现崩溃的现象,开发者个人不可能购买所有设备逐个调试,所以在程序发布出去之后,如果出现了 ...

  2. 高级iOS面试题

    非标准答案 2 1: 类方法是可以直接通过类名直接调用,无需进行实例化对象.类方法是以+开头2. 实例方法,需要显示实例化对象,为对象分配堆栈空间,并通过对象实例调用实例方法3. RUNTIME 是在 ...

  3. SSH整合简述一

    1.web.xml中配置 struts2过滤器 <filter> <filter-name>struts2</filter-name> <filter-cla ...

  4. OC-分类

    1.不能再分类里面添加属性, 只能添加方法. 2.如果在分类里面使用@property,那么他只生成sette,getter的声明而没有实现. 3.如在在分类中写了与本类同名的方法,优先调用分类里面的 ...

  5. 【Adaboost算法】C++转C, 分类器结构设计

    一.参考OpenCV的CascadeClassifier类LBPEvaluator类 如下,筛选出存放分类器相关信息的成员变量: class CV_EXPORTS_W CascadeClassifie ...

  6. bsearch

    在java中为了避免 low+high溢出,可以用无符号右移:正数高位补0,负数高位补1 int mid = (low + high) >>> 1; 如果是在c++中,那么需要先转换 ...

  7. 图解 SQL 各种连接查询之间的区别

    转载自:http://blog.csdn.net/xuanjiewu/article/details/50636465 对于SQL的Join,在学习起来可能是比较乱的.我们知道,SQL的Join语法有 ...

  8. C#调用C++ DLL 文件

    说来惭愧,都注册一年多了,却没有发表过一篇正式的博文,中间很多学习的过程也没有记录下来.如今到了一个新的环境,也有了学习的机会,一定要把每天的收获记录一下. 要做的东西需要引用C++编写的DLL,刚开 ...

  9. HTML5不支持标签和新增标签

    1.HTML5不支持或不赞成使用的标签 <acronym>——定义只取首字母的缩写,HTML5 不支持.使用<abbr>定义缩写代替,其中title 属性可用于在鼠标指针移动到 ...

  10. 对象复制问题 && lvalue-rvalue && 引用

    按值传递实参到函数和函数返回临时变量的副本,函数的效率对执行性能来说至关重要 如果避免这样的复制操作,则执行时间可能会大大缩短. class CMessage { private: char * m_ ...