Android驱动开发之Hello实例:
驱动部分
modified:   kernel/arch/arm/configs/msm8909-1gb_w100_hd720p-perf_defconfig
modified:   kernel/arch/arm/configs/msm8909-1gb_w100_hd720p_defconfig
modified:   kernel/drivers/input/misc/Kconfig
modified:   kernel/drivers/input/misc/Makefile
kernel/drivers/input/misc/hello.c
FFBM部分:用来测试驱动是否正常运行
modified:   vendor/qcom/proprietary/common/build/fastmmi/mmi.mk
modified:   vendor/qcom/proprietary/fastmmi/res/config/mmi-W200_W.cfg
modified:   vendor/qcom/proprietary/fastmmi/res/layout/Android.mk
modified:   vendor/qcom/proprietary/fastmmi/res/values/strings.xml
vendor/qcom/proprietary/fastmmi/module/hello/
vendor/qcom/proprietary/fastmmi/module/hello/Android.mk
vendor/qcom/proprietary/fastmmi/module/hello/hello.cpp
vendor/qcom/proprietary/fastmmi/res/layout/layout_hello.xml
SELinux安全,用来允许mmi访问/dev/hello节点
modified:   device/qcom/sepolicy/common/mmi.te
modified:   external/sepolicy/device.te
modified:   external/sepolicy/file_contexts

1) kernel/drivers/input/misc/hello.c
#include <linux/types.h>
#include <linux/module.h>
#include <linux/fs.h>
#include <linux/init.h>
#include <linux/cdev.h>
#include <linux/device.h>
#include <linux/slab.h>
#include <asm/uaccess.h>
MODULE_AUTHOR("zhaopuqing");
MODULE_LICENSE("Dual BSD/GPL");
MODULE_VERSION("hello v1.0");
MODULE_ALIAS("Hello");
#define DEVICE_SUM 1
static int hello_open(struct inode *inode, struct file *filp);
static int hello_release(struct inode *, struct file *filp);
static ssize_t hello_read(struct file*, char*, size_t, loff_t*);
static ssize_t hello_write(struct file*, const char*, size_t, loff_t*);
/*the major device number*/
static int hello_major = 0;
static int hello_minor = 0;
static struct class* hello_class = NULL;
/*init the file_operations structure*/
struct file_operations hello_fops = {
.owner = THIS_MODULE,
.open = hello_open,
.release = hello_release,
.read = hello_read,
.write = hello_write,
};
struct cdev *cdev;
static int global_var = 0; /*global var*/
/*module init*/
static int __init hello_init(void){
int ret = 0;
struct device* temp = NULL;
dev_t devno = 0;
printk("hello:hello_init.\n");
ret = alloc_chrdev_region(&devno, hello_minor, DEVICE_SUM, "hello");
if(ret < 0){
printk(KERN_ALERT"hello:Failed to alloc char dev region.\n");
goto fail;
}
hello_major = MAJOR(devno);
hello_minor = MINOR(devno);
cdev = cdev_alloc();
cdev->owner = THIS_MODULE;
cdev->ops = &hello_fops;
if((ret = cdev_add(cdev, devno, 1))){
printk(KERN_NOTICE"Hello:Error%d adding hello.\n", ret);
return 0;
}else{
printk(KERN_ALERT"hello:hello register success.\n");
}
hello_class = class_create(THIS_MODULE, "hello");
if(IS_ERR(hello_class)){
ret = PTR_ERR(hello_class);
printk(KERN_ALERT"Failed to create hello class.\n");
goto destroy_cdev;
}
temp = device_create(hello_class, NULL, devno, "%s", "hello");
if(IS_ERR(temp)){
ret = PTR_ERR(temp);
printk(KERN_ALERT"Failed to create hello device.");
goto destroy_class;
}
return ret;
destroy_class:
class_destroy(hello_class);
destroy_cdev:
cdev_del(cdev);
fail:
return ret;
}
static void __exit hello_exit(void){
dev_t devno = MKDEV(hello_major, 0);
printk(KERN_ALERT"Goodbye, cruel world\n");
/*remove cdev from kernel*/
cdev_del(cdev);
/*unregister the device device driver*/
unregister_chrdev_region(devno, 1);
/*free the dev structure*/
if(cdev)
kfree(cdev);
cdev = NULL;
}
/*open device*/
static int hello_open(struct inode *inode, struct file *filp){
int ret = 0;
printk(KERN_ALERT"kernel:open success.\n");
return ret;
}
/*release device*/
static int hello_release(struct inode *inode, struct file *filp){
printk(KERN_ALERT"kernel:release success.\n");
return 0;
}
/*read device*/
static int hello_read(struct file *filp, char *buf, size_t len, loff_t *off){
printk(KERN_ALERT"kernel:reading...\n");
if(copy_to_user(buf, &global_var, sizeof(int))){
return -EFAULT;
}
return sizeof(int);
}
/*write device*/
static ssize_t hello_write(struct file *filp, const char *buf, size_t len, loff_t *off){
printk(KERN_ALERT"kernel:writing...\n");
if(copy_from_user(&global_var, buf, sizeof(int))){
return -EFAULT;
}
return sizeof(int);
}
/*module register*/
module_init(hello_init);
module_exit(hello_exit);

******************************************************
2) kernel/drivers/input/misc/Kconfig
config SENSORS_HELLO
tristate "Hello"
depends on SPI=y
help
If you say yes here you get supoort for Hello's
hello test.

******************************************************
3) kernel/drivers/input/misc/Makefile
obj-$(CONFIG_SENSORS_HELLO)     += hello.o
******************************************************
4) kernel/arch/arm/configs/msm8909-1gb_w100_hd720p-perf_defconfig
CONFIG_SENSORS_HELLO=y
*******************************************************
5) kernel/arch/arm/configs/msm8909-1gb_w100_hd720p_defconfig
CONFIG_SENSORS_HELLO=y
**************************************************
6) vendor/qcom/proprietary/fastmmi/module/hello/hello.cpp
#include "mmi_module.h"
#define TAG "Hello"
#define DEVICE_NAME "/dev/hello"
#define HELLO_TEST_WAIT "hello test,please waitting...."
#define HELLO_TEST_SUCCESS "hello test success!"
#define HELLO_TEST_FAILED "hello test failed!"
static const mmi_module_t* g_module;
static unordered_map < string, string > paras;
static void cb_function(const char *str, int size){
if(g_module != NULL){
g_module->cb_print(paras[KEY_MODULE_NAME].c_str(),SUBCMD_MMI, str, size, PRINT);
}
}
int hello_test(){
ALOGI("%s : %s start!\n", TAG, __FUNCTION__);
int fd = -1;
int val = 0;
fd = open(DEVICE_NAME, O_RDWR);
if(fd <= 0){
ALOGI("%s : %s open device [%s] failed!\n", TAG, __FUNCTION__, DEVICE_NAME);
return FAILED;
}
ALOGI("%s : %s start to read device info!\n", TAG, __FUNCTION__);
read(fd, &val, sizeof(val));
ALOGI("%s : %s read value=%d\n", TAG, __FUNCTION__, val);
ALOGI("********************************************\n");
val = 5;
ALOGI("%s : %s start write value %d to %s\n", TAG, __FUNCTION__, val, DEVICE_NAME);
write(fd, &val, sizeof(val));
ALOGI("*********************************************\n");
ALOGI("%s : %s read device value again!\n", TAG, __FUNCTION__);
read(fd, &val, sizeof(val));
ALOGI("%s : %s read value=%d\n", TAG, __FUNCTION__, val);
close(fd);
return SUCCESS;
}
static int32_t module_init(const mmi_module_t * module, unordered_map < string, string > &params){
ALOGI("%s : %s start!\n", TAG, __FUNCTION__);
if(module == NULL){
ALOGE("%s : %s NULL point received!\n", __FUNCTION__);
return FAILED;
}
return SUCCESS;
}
static int32_t module_deinit(const mmi_module_t * module){
ALOGI("%s : %s start!\n", TAG, __FUNCTION__);
if(module == NULL){
ALOGE("%s : %s NULL point received!\n", TAG, __FUNCTION__);
return FAILED;
}
return SUCCESS;
}
static int32_t module_run(const mmi_module_t * module, const char *cmd, unordered_map < string ,string > &params){
int ret = FAILED;
if(!module || !cmd){
ALOGE("%s : %s NULL point received!\n", TAG, __FUNCTION__);
return FAILED;
}
g_module = module;
paras = params;
ALOGI("%s start.command : %s\n", __FUNCTION__, cmd);
cb_function(HELLO_TEST_WAIT, strlen(HELLO_TEST_WAIT));
if(!strcmp(cmd, SUBCMD_MMI)){
ret = hello_test();
if(ret != SUCCESS){
    ALOGE("%s : %s open hello module failed!\n", TAG, __FUNCTION__);
    cb_function(HELLO_TEST_FAILED, strlen(HELLO_TEST_FAILED));
}else{
    ALOGI("%s : %s open hello module success!\n", TAG, __FUNCTION__);
    cb_function(HELLO_TEST_SUCCESS, strlen(HELLO_TEST_SUCCESS));
}
}else if(!strcmp(cmd, SUBCMD_PCBA)){
}else{
ALOGE("%s : %s Invalid command : %s received!\n", TAG, __FUNCTION__, cmd);
ret = FAILED;
}
return ret;
}
static int32_t module_stop(const mmi_module_t *module){
ALOGI("%s : %s start.\n", __FUNCTION__);
if(module == NULL){
ALOGE("%s : %s NULL point received!\n", TAG, __FUNCTION__);
return FAILED;
}
pthread_kill(module->run_pid, SIGUSR1);
return SUCCESS;
}
static struct mmi_module_methods_t module_methods = {
.module_init = module_init,
.module_deinit = module_deinit,
.module_run = module_run,
.module_stop = module_stop,
};
mmi_module_t MMI_MODULE_INFO_SYM = {
.version_major = 1,
.version_minor = 0,
.name = "Hello",
.author = "Hello test",
.methods = &module_methods,
.module_handle = NULL,
.supported_cmd_list = NULL,
.supported_cmd_list_size = 0,
.cb_print = NULL,
.run_pid = -1,
};

*****************************************************
7) vendor/qcom/proprietary/fastmmi/module/hello/Android.mk
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE_OWNER := qti
LOCAL_PROPRIETARY_MODULE := true
LOCAL_SRC_FILES := hello.cpp
LOCAL_MODULE := mmi_hello
LOCAL_CLANG := false
LOCAL_MODULE_TAGS := optional
LOCAL_CFLAGS := -Wall
LOCAL_C_INCLUDES := external/libcxx/include \
    $(QC_PROP_ROOT)/fastmmi/libmmi
LOCAL_SHARED_LIBRARIES := libcutils libutils libmmi libhardware libc++
LOCAL_C_INCLUDES += $(TARGET_OUT_INTERMEDIATES)/KERNEL_OBJ/usr/include
ifeq ($(TARGET_COMPILE_WITH_MSM_KERNEL), true)
LOCAL_ADDITIONAL_DEPENDENCIES := $(TARGET_OUT_INTERMEDIATES)/KERNEL_OBJ/usr
endif
include $(BUILD_SHARED_LIBRARY)

********************************************************
8) vendor/qcom/proprietary/fastmmi/res/layout/layout_hello.xml
<?xml version="1.0" encoding="utf-8"?>
<layout>
<include layout="header.xml" />
<button
name="instruction"
text="hello_notice"
w_rel="100"
h_rel="10"
x_rel="0"
y_rel="12"
color="0x007D7DFF" />
<textview
name="display"
text=""
w_rel="100"
h_rel="60"
x_rel="4"
y_rel="27" />
<include layout="footer.xml" />
</layout>

********************************************
9) vendor/qcom/proprietary/fastmmi/res/values/strings.xml
<string name="hello">Hello</string>
<string name="hell_notice">Hello test, just for test!</string>

**************************************************
10) vendor/qcom/proprietary/fastmmi/res/layout/Android.mk
include $(CLEAR_VARS)
LOCAL_SRC_FILES := layout_hello.xml
LOCAL_CFLAGS := -Wall
LOCAL_MODULE := layout_hello.xml
LOCAL_MODULE_CLASS := ETC
LOCAL_MODULE_TAGS := optional
LOCAL_MODULE_PATH := $(TARGET_OUT_ETC)/mmi/layout
include $(BUILD_PREBUILT)

***************************************************
11) vendor/qcom/proprietary/fastmmi/res/config/mmi-W200_W.cfg
[HELLO]
lib_name=mmi_hello.so
enable=1
automation=0
display_name=hello
layout=layout_hello.xml

**********************************************
12) vendor/qcom/proprietary/common/build/fastmmi/mmi.mk
MMI += mmi_hello
MMI_RES += layout_hello.xml
************************************************
13) external/sepolicy/device.te
#hello test
type hello_device, dev_type;

************************************************
14) external/sepolicy/file_contexts
#hello test
/dev/hello    u:object_r:hello_device:s0

***************************************************
15) device/qcom/sepolicy/common/mmi.te
allow mmi hello_device:chr_file {open read write};
以上为全部测试代码:
打印内核消息为:adb shell cat /proc/kmsg

转载于:https://www.cnblogs.com/wanghuaijun/p/7749414.html

Android驱动开发之Hello实例相关推荐

  1. Android驱动开发之Hello实例(基于高通msm8909)

    点击打开链接 Android驱动开发之Hello实例: 驱动部分 modified:   kernel/arch/arm/configs/msm8909-1gb_w100_hd720p-perf_de ...

  2. Android驱动开发之earlysuspend睡眠模式--实现代码

    (1)添加头文件: #include <linux/earlysuspend.h> (2)在特定驱动结构体中添加early_suspend结构: #ifdef CONFIG_HAS_EAR ...

  3. Android底层开发之Audio HAL Android Audio Overview

    http://blog.csdn.net/kangear/article/details/44939429 Android底层开发之Audio HAL 在Android音频底层调试-基于tinyals ...

  4. Android关掉多个activity,Android应用开发之Android Activity栈管理 制定关闭某一个Activity,关闭所有Activit...

    本文将带你了解Android应用开发之Android Activity栈管理  制定关闭某一个Activity,关闭所有Activit,希望本文对大家学Android有所帮助. 系统Api :打开新的 ...

  5. android 控制app声音,Android底层开发之APP音量单独控制

    Android底层开发之APP音量单独控制 目前Android的音乐播放软件都的音量控制都是随着系统的总Master音量变化的.想要实现和windows中一样,每个APP的媒体音量可以单独控制. 控制 ...

  6. android实现qq表情库,Android编程开发之EditText实现输入QQ表情图像的方法

    本文实例讲述了Android编程开发之EditText实现输入QQ表情图像的方法.分享给大家供大家参考,具体如下: 实现效果如下: 将QQ表情图像放到res下的drawable-hdpi文件夹下: 布 ...

  7. 【转载】Android逆向开发之smali语言的学习

    Android逆向开发之smali语言的学习 该文转载自乱码三千 – 分享实用IT技术 smali和java基本数据类型对比 smali java B byte S short I int J lon ...

  8. Android底层开发之Audio HAL

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! Andr ...

  9. 镜像处理坐标 android,Android应用开发之Android重写ImageView实现图片镜像效果的代码教程...

    本文将带你了解Android应用开发之Android重写ImageView实现图片镜像效果的代码教程,希望本文对大家学Android有所帮助. 前两天朋友问我一个问题,如何实现从手机系统相册加载一张图 ...

最新文章

  1. Leetcode 198.打家劫舍 (每日一题 20210622)
  2. Git 基本操作教程
  3. oracle备份还原到本地_Oracle 11g R2 RAC数据库备份通过RMAN恢复到单实例数据库实现...
  4. 黑马程序员C++学习笔记(第二阶段核心:面向对象)(二)
  5. 110. PHP 读取 ini ,ftp 上传
  6. DTCC技术大会来了
  7. keras深度训练4:GPU设置
  8. 苹果开发者账号申请流程
  9. Python程序之DNS劫持
  10. 【学习笔记】《Writing Science》10-13
  11. Android应用商店的软件安全性到底如何?
  12. oracle语句update使用case when连续更新
  13. 一篇文章详细介绍什么是回调地狱
  14. NUMA与英特尔Xeon处理器学习心得 转
  15. php 生存分析,生存分析与R--转载
  16. 关于决策树可视化各项展示数据的解读(泰坦尼克号预测生还案例Titanic)
  17. [Visual Assist]快速创建实现
  18. ESP8266乐鑫版本的(支持云端升级 (Boot 模式)烧写方法,(V1.5.4官方介绍如下)(BOOT模式)...
  19. Python悬浮可移动置顶计时软件AttentionPlease
  20. 有源RFID技术部署,需考虑哪些因素?

热门文章

  1. 在阿里做博士后是一种怎样的体验?
  2. 文件按m3u8顺序合并_在线视频下载之m3u8篇
  3. 制作精良、意犹未尽的异色推理小剧场《Tangle Tower 缠结塔》
  4. mysql堵塞 sending data和sort状态多,cpu高
  5. MySQL查询报错ERROR:No query specified
  6. 三星I9100[4.0 固件ROM] [2012.03.15]万众期待的欧版官方4.0.3完美汉化完美教程
  7. C++11 initializer_list 和 Range-based for loop 学习理解
  8. [WPF]使用Fody提高效率
  9. socket.io c++库编译不成功的注意事项
  10. LeetCode Search in Rotated Sorted Array II -- 有重复的旋转序列搜索