Android MediaTek 平台增加UART接口的红外模块支持,支持NEC红外遥控
目录
修改的文件:
文件修改说明:
这个是mtk 增加的uart和nec红外模块的支持 , 以下主要针对driver的增加 , 应用部分也有 需要的可以私。
这个 修改主要在 MediaTek 平台上添加了红外接收驱动。这个驱动可以接收红外信号,并将其转换为对应的按键事件。
修改的文件:
device/btf/xxx8735_xxx/device.mk
kernel-3.10/drivers/misc/mediatek/Makefile.mt6735
kernel-3.10/drivers/misc/mediatek/ir/Makefile
kernel-3.10/drivers/misc/mediatek/ir/irrx.c
kernel-3.10/drivers/misc/mediatek/ir/irrx.h
packages/apps/IrrxService/Android.mk
packages/apps/IrrxService/IrrxService.apk
packages/apps/IrrxService/libs/arm/libserial_port.so
packages/apps/IrrxService/libs/arm64/libserial_port.so
文件修改说明:
device.mk
: 在产品包中添加了红外服务的库文件和 APK 文件。Makefile.mt6735
: 在 MediaTek 平台的驱动 Makefile 中添加了红外驱动的编译选项。Makefile
: 创建了红外驱动的 Makefile 文件,用于编译红外驱动的源代码文件。irrx.c
: 创建了红外驱动的源代码文件,实现了红外接收驱动的主要功能。irrx.h
: 创建了红外驱动的头文件,定义了红外驱动的数据结构和接口。Android.mk
: 创建了红外服务的 Makefile 文件,用于编译红外服务的 APK 文件和库文件。IrrxService.apk
: 添加了红外服务的 APK 文件,这是一个 Android 应用,用于接收红外驱动的按键事件,并将其转发给其他应用。libserial_port.so
: 添加了红外服务的库文件,这个库提供了串口通信的功能,用于接收红外信号。libserial_port.so
: 添加了红外服务的库文件,这个库提供了串口通信的功能,用于接收红外信号。
---device/btf/xxx8735_xxx/device.mk | 8 +kernel-3.10/drivers/misc/mediatek/Makefile.mt6735 | 1 +kernel-3.10/drivers/misc/mediatek/ir/Makefile | 5 +kernel-3.10/drivers/misc/mediatek/ir/irrx.c | 257 +++++++++++++++++++++kernel-3.10/drivers/misc/mediatek/ir/irrx.h | 17 ++packages/apps/IrrxService/Android.mk | 11 +packages/apps/IrrxService/IrrxService.apk | Bin 0 -> 1774274 bytes.../apps/IrrxService/libs/arm/libserial_port.so | Bin 0 -> 5132 bytes.../apps/IrrxService/libs/arm64/libserial_port.so | Bin 0 -> 9616 bytes9 files changed, 299 insertions(+)create mode 100755 kernel-3.10/drivers/misc/mediatek/ir/Makefilecreate mode 100755 kernel-3.10/drivers/misc/mediatek/ir/irrx.ccreate mode 100755 kernel-3.10/drivers/misc/mediatek/ir/irrx.hcreate mode 100755 packages/apps/IrrxService/Android.mkcreate mode 100755 packages/apps/IrrxService/IrrxService.apkcreate mode 100755 packages/apps/IrrxService/libs/arm/libserial_port.socreate mode 100755 packages/apps/IrrxService/libs/arm64/libserial_port.sodiff --git a/device/btf/xxx8735_xxx/device.mk b/device/btf/xxx8735_xxx/device.mk
index 04bad6c..7be7c41 100755
--- a/device/btf/xxx8735_xxx/device.mk
+++ b/device/btf/xxx8735_xxx/device.mk
@@ -255,9 +255,17 @@ PRODUCT_PACKAGES += updateMac \FactoryMode#endif+#shh add ir
+PRODUCT_COPY_FILES += \
+ packages/apps/IrrxService/libs/arm/libserial_port.so:system/lib/libserial_port.so \
+ packages/apps/IrrxService/libs/arm64/libserial_port.so:system/lib64/libserial_port.so
+
+PRODUCT_PACKAGES += IrrxService
+PRODUCT_PACKAGES += UsbCameraPRODUCT_PACKAGES += HdmiIn4a90PRODUCT_PACKAGES += EasyBox
+#PRODUCT_PACKAGES += BtfFactoryMode#PRODUCT_PACKAGES += A90_Test#PRODUCT_PACKAGES += Firefox
diff --git a/kernel-3.10/drivers/misc/mediatek/Makefile.mt6735 b/kernel-3.10/drivers/misc/mediatek/Makefile.mt6735
index 41d61b0..c912fa4 100755
--- a/kernel-3.10/drivers/misc/mediatek/Makefile.mt6735
+++ b/kernel-3.10/drivers/misc/mediatek/Makefile.mt6735
@@ -13,6 +13,7 @@ endifobj-y += kpd_gpio/obj-y += panel_dir/obj-y += hdmi_det/
+obj-y += ir/obj-$(CONFIG_MTK_CPU_STRESS) += cpu_stress/obj-$(CONFIG_MTK_LASTPC) += lastpc/
diff --git a/kernel-3.10/drivers/misc/mediatek/ir/Makefile b/kernel-3.10/drivers/misc/mediatek/ir/Makefile
new file mode 100755
index 0000000..cec12b2
--- /dev/null
+++ b/kernel-3.10/drivers/misc/mediatek/ir/Makefile
@@ -0,0 +1,5 @@
+include $(srctree)/drivers/misc/mediatek/Makefile.custom
+
+obj-y += irrx.o
+
+
diff --git a/kernel-3.10/drivers/misc/mediatek/ir/irrx.c b/kernel-3.10/drivers/misc/mediatek/ir/irrx.c
new file mode 100755
index 0000000..e10551f
--- /dev/null
+++ b/kernel-3.10/drivers/misc/mediatek/ir/irrx.c
@@ -0,0 +1,257 @@
+/*
+ * Copyright (C) 2010 Trusted Logic S.A.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+#include <linux/kernel.h>
+#include <linux/module.h>
+#include <linux/fs.h>
+#include <linux/slab.h>
+#include <linux/init.h>
+#include <linux/list.h>
+#include <linux/i2c.h>
+#include <linux/irq.h>
+#include <linux/jiffies.h>
+#include <linux/uaccess.h>
+#include <linux/delay.h>
+#include <linux/interrupt.h>
+#include <linux/io.h>
+#include <linux/platform_device.h>
+#include <linux/gpio.h>
+#include <linux/miscdevice.h>
+#include <linux/spinlock.h>
+#include <linux/dma-mapping.h>
+#include <mach/mt_gpio.h>
+#include <mach/eint.h>
+#include <cust_gpio_usage.h>
+#include <cust_eint.h>
+#include <linux/wakelock.h>
+#include <mach/mt_pm_ldo.h>
+#include <linux/input.h>
+
+#include "irrx.h"
+
+#define DBG(x...) printk(x)
+
+#define IR_NAME "irrx"
+
+struct irRx_platform_data {
+ struct input_dev *input;
+
+};
+struct mutex write_mutex;
+static unsigned int key_map[] = {
+ KEY_ESC,
+ KEY_1,
+ KEY_2,
+ KEY_3,
+ KEY_4,
+ KEY_5,
+ KEY_6,
+ KEY_7,
+ KEY_8,
+ KEY_9,
+ KEY_0,
+ KEY_BACKSPACE,
+ KEY_ENTER,
+ KEY_HOME,
+ KEY_UP,
+ KEY_PAGEUP,
+ KEY_LEFT,
+ KEY_RIGHT,
+ KEY_END,
+ KEY_DOWN,
+ KEY_PAGEDOWN,
+ KEY_INSERT,
+ KEY_DELETE,
+ KEY_MACRO,
+ KEY_MUTE,
+ KEY_VOLUMEDOWN,
+ KEY_VOLUMEUP,
+ KEY_POWER,
+ KEY_PAUSE,
+ KEY_STOP,
+ KEY_COPY,
+ KEY_MENU,
+ KEY_SETUP,
+ KEY_SLEEP,
+ KEY_WAKEUP,
+ KEY_BACK,
+ KEY_PLAYPAUSE,
+ KEY_EXIT,
+ KEY_CLOSE,
+ KEY_PLAY,
+ KEY_SOUND,
+ KEY_SEARCH,
+ KEY_SAVE,
+ KEY_HDMI_IN,
+ KEY_BTF_1,
+ KEY_BTF_2,
+ KEY_BTF_3,
+ KEY_BTF_4,
+ KEY_BTF_5,
+ KEY_BTF_6,
+ KEY_BTF_7,
+ KEY_BTF_8,
+ KEY_BTF_9,
+ KEY_OK ,
+ KEY_SELECT,
+ KEY_CLEAR,
+
+};
+
+static struct irRx_platform_data g_irRxPdata;
+
+
+static void report_key(unsigned int key)
+{
+ int i = 0;
+ if (key == 0)
+ return;
+ for (i = 0;i < sizeof(key_map)/sizeof(key_map[0]);i++)
+ {
+ if (key == key_map[i])
+ {
+ input_report_key(g_irRxPdata.input, key_map[i], 1);
+ input_sync(g_irRxPdata.input);
+ input_report_key(g_irRxPdata.input, key_map[i], 0);
+ input_sync(g_irRxPdata.input);
+ break;
+ }
+ }
+}
+
+static ssize_t irrx_debug_store(struct class *class, struct class_attribute *attr,
+ const char *buf, size_t count)
+{
+ int value = 0;
+ ssize_t ret = 0;
+ if (!count) return count;
+ ret = sscanf(buf,"%d",&value);
+ if (ret != 1)
+ return -EINVAL;
+ report_key(value);
+ return count;
+}
+
+static struct class_attribute irrx_class_attrs[] = {
+ __ATTR(state,0222,NULL,irrx_debug_store),
+ __ATTR_NULL,
+};
+
+static struct class irrx_cls = {
+ .name = "irrx",
+ .class_attrs = irrx_class_attrs,
+};
+
+static int ir_open(struct inode *inode, struct file *file)
+{
+
+ return 0;
+
+}
+
+static ssize_t ir_write(struct file *filp, const char __user *buf, size_t count, loff_t *offset)
+{
+ char buffer[10] = {0};
+ unsigned int key = 0;
+ mutex_lock(&write_mutex);
+ if (copy_from_user(buffer, buf, count))
+ {
+ printk("%s copy from user err\n",__func__);
+ mutex_unlock(&write_mutex);
+ return -EFAULT;
+ }
+
+ if (count >= 2) {
+ key = (buffer[0] << 8) | buffer[1];
+ report_key(key);
+ }
+ mutex_unlock(&write_mutex);
+ return count;
+}
+
+static const struct file_operations ir_fops_dev = {
+ .owner = THIS_MODULE,
+ .open = ir_open,
+ .write = ir_write,
+};
+
+static struct miscdevice ir_misc_dev = {
+ .minor = MISC_DYNAMIC_MINOR,
+ .name = IR_NAME,
+ .fops = &ir_fops_dev,
+
+};
+
+
+static int __init irRx_init(void)
+{
+ int ret = 0;
+ int i = 0;
+
+ g_irRxPdata.input = input_allocate_device();
+ if (!g_irRxPdata.input) {
+ ret = -1;
+ return ret;
+ }
+
+ g_irRxPdata.input->name = "irrx";
+ g_irRxPdata.input->phys = "irrx/input3";
+
+ g_irRxPdata.input->id.bustype = BUS_HOST;
+ g_irRxPdata.input->id.vendor = 0x0001;
+ g_irRxPdata.input->id.product = 0x0001;
+ g_irRxPdata.input->id.version = 0x0100;
+
+ for (i = 0;i < sizeof(key_map)/sizeof(key_map[0]);i++)
+ input_set_capability(g_irRxPdata.input, EV_KEY,key_map[i]);
+ ret = input_register_device(g_irRxPdata.input);
+ if (ret) {
+
+ goto fail1;
+ }
+ mutex_init(&write_mutex);
+
+ ret = misc_register(&ir_misc_dev);
+ if (ret) {
+ goto fail2;
+ }
+ class_register(&irrx_cls);
+ return ret;
+ fail2:
+ input_unregister_device(g_irRxPdata.input);
+ fail1:
+ input_free_device(g_irRxPdata.input);
+ g_irRxPdata.input = NULL;
+ return ret;
+}
+
+static void __exit irRx_exit(void)
+{
+ input_unregister_device(g_irRxPdata.input);
+ input_free_device(g_irRxPdata.input);
+ g_irRxPdata.input = NULL;
+ misc_deregister(&ir_misc_dev);
+}
+
+module_init(irRx_init);
+module_exit(irRx_exit);
+
+MODULE_AUTHOR("XXX");
+MODULE_DESCRIPTION("IR input driver");
+MODULE_LICENSE("GPL");
diff --git a/kernel-3.10/drivers/misc/mediatek/ir/irrx.h b/kernel-3.10/drivers/misc/mediatek/ir/irrx.h
new file mode 100755
index 0000000..e479118
--- /dev/null
+++ b/kernel-3.10/drivers/misc/mediatek/ir/irrx.h
@@ -0,0 +1,17 @@
+/*
+ * Copyright (C) 2010 Trusted Logic S.A.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
diff --git a/packages/apps/IrrxService/Android.mk b/packages/apps/IrrxService/Android.mk
new file mode 100755
index 0000000..7c1518c
--- /dev/null
+++ b/packages/apps/IrrxService/Android.mk
@@ -0,0 +1,11 @@
+LOCAL_PATH := $(call my-dir)
+include $(CLEAR_VARS)
+# Module name should match apk name to be installed
+LOCAL_MODULE := IrrxService
+LOCAL_MODULE_TAGS := optional
+LOCAL_DEX_PREOPT := false
+LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
+LOCAL_MODULE_CLASS := APPS
+LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
+LOCAL_CERTIFICATE := platform
+include $(BUILD_PREBUILT)
\ No newline at end of file
diff --git a/packages/apps/IrrxService/IrrxService.apk b/packages/apps/IrrxService/IrrxService.apk
Android MediaTek 平台增加UART接口的红外模块支持,支持NEC红外遥控相关推荐
- 利用声音传感器控制led灯功能_树莓派 LED+蜂鸣+声音传感器+红外模块组合打造声控/红外控制LED...
昨天搞了控制LED,玩了第一个,剩下的就感觉很简单了,这里记录一下 先来几张照片 玩了蜂蜜模块才发现规律,一般这种模块,都会有三个针脚,VCC(3.3V或5V供电输出针脚).GNC(对应GPIO针脚的 ...
- 迅宏超低成本双卡双待Android手机平台量产,价格低于1000元
一台精致的双卡双待单通Android智能机,反应速度.视频效果.界面.软件设置和外观的体验都不错,据说山寨市场售价才680元.目前已有打着国内著名品牌的机型出口到印度运营商Sataria. 它的主芯片 ...
- Arduino 红外模块 红外接收 红外发射
需要用到IRremote库文件 红外遥控按键16进制编码,使用时添加前缀 0X 红外接收 .源代码 //***************** //红外接收模块测试 //***************** ...
- Android 功耗(10)---如何测试 Mediatek 平台各个场景的功耗数据?
如何测试 Mediatek 平台各个场景的功耗数据? [DESCRIPTION] 很多功耗问题都是因为测试手法不对,该FAQ列出一些常用场景功耗测试手法. [SOLUTION] 测试功耗数据之前,请先 ...
- Android 功耗(11)---如何测试 Mediatek 平台各个场景的功耗数据?
如何测试 Mediatek 平台各个场景的功耗数据? 很多功耗问题都是因为测试手法不对,该FAQ列出一些常用场景功耗测试手法. 测试功耗数据之前,请先确认以下配置: 1.关闭 WIFI/BT/GPS, ...
- Android P 9.0 MTK平台 增加以太网静态IP功能
前言 朋友们,最近又开始搞 Android P了,同样的以太网静态 IP 是少不了的功能,今天我们就开始来整一下.之前弄6.0 和 8.1 的都 ok 了. 没想到 9.0 改动还是略微有点大的.来来 ...
- android红外模块,基于Android平台的智能家居红外控制系统的研究
摘要: 计算机技术,网络通信技术,智能传感技术,微电子技术的成熟和发展为智能家居的发展创造了良好的前提条件和基础.但现有的家居系统中都存在不足和缺点,而且在智能方面还存在较大的空白.本文针对这些不足和 ...
- 一篇读懂:Android手机如何通过USB接口与外设通信(附原理分析及方案选型)
更多技术干货,欢迎扫码关注博主微信公众号:HowieXue,共同探讨软件知识经验,关注就有海量学习资料免费领哦: 目录 0背景 1.手机USB接口通信特点 1.1 使用方便 1.2 通用性强 1.3 ...
- Android 推送消息开放接口 OpenPush
Android 推送消息开放接口 OpenPush 我们知道, 在中国不能使用 google 的服务. 在中国销售的手机甚至没有安装 google 的服务.所以, 原本由 google gcm 提供的 ...
最新文章
- 西工大计算机专业课考什么,我的西北工业大学计算机考研之路总结
- python 拆分excel openpyxl_openpyxl(python操作Excel)
- part-time job
- 窦学计算机基础期末考试,关于新生开学考计算机基础
- tomcat 错误页面html,Nginx整合Tomcat后配置友好错误界面
- php oracle 大字段,php oracle数据库clob和nclob字段
- Ubuntu18.04之星际译王及辞典
- Android端身份证识别
- Ubuntu16安装搜狗拼音输入法
- gif动图怎么制作?怎么截取视频做成gif动图?
- java程序员书单--成长之路--职业发展,你读过几本
- sql server case when then else end as 用法
- 编程初学者入门训练-KiKi和酸奶
- hannoi塔(汉诺塔)移动过程解析
- 2345浏览器如何启用过滤弹窗广告
- MySQL数据库优化高频面试题(最新版)
- 使用HFS+cpolar组合 低成本搭建NAS(1)
- 基于freeradius的无线认证
- Python 处理Excel内的数据(案例介绍*2)
- openvas(开放式漏洞评估系统)
热门文章
- 【运动学】不等半径泊车方法matlab仿真
- 《Minecraft》——游戏介绍
- 千与千寻 一个10岁小女孩的内心世界
- RIDE用到chrome浏览器:Message: ‘chromedriver‘ executable needs to be in PATH.
- 浅析500G硬盘为何容量不够?
- Java入门系列之访问修饰符作用范围
- linux下QQ下载官网
- Win10中装Win10---virtualbox虚拟机的安装及拓展
- 2015年基于宏的恶意软件数量再次飙升
- SSL漏洞 TLS/SSL Sweet32 attack || TLS/SSL Wrak Cipher Suites[解决]