Android MediaTek 平台增加UART接口的红外模块支持,支持NEC红外遥控

简介: Android MediaTek 平台增加UART接口的红外模块支持,支持NEC红外遥控

这个是mtk 增加的uart和nec红外模块的支持 , 以下主要针对driver的增加 , 应用部分也有 需要的可以私。

这个 修改主要在 MediaTek 平台上添加了红外接收驱动。这个驱动可以接收红外信号,并将其转换为对应的按键事件。

修改的文件:

  1. device/btf/xxx8735_xxx/device.mk
  2. kernel-3.10/drivers/misc/mediatek/Makefile.mt6735
  3. kernel-3.10/drivers/misc/mediatek/ir/Makefile
  4. kernel-3.10/drivers/misc/mediatek/ir/irrx.c
  5. kernel-3.10/drivers/misc/mediatek/ir/irrx.h
  6. packages/apps/IrrxService/Android.mk
  7. packages/apps/IrrxService/IrrxService.apk
  8. packages/apps/IrrxService/libs/arm/libserial_port.so
  9. packages/apps/IrrxService/libs/arm64/libserial_port.so

文件修改说明:

  1. device.mk: 在产品包中添加了红外服务的库文件和 APK 文件。
  2. Makefile.mt6735: 在 MediaTek 平台的驱动 Makefile 中添加了红外驱动的编译选项。
  3. Makefile: 创建了红外驱动的 Makefile 文件,用于编译红外驱动的源代码文件。
  4. irrx.c: 创建了红外驱动的源代码文件,实现了红外接收驱动的主要功能。
  5. irrx.h: 创建了红外驱动的头文件,定义了红外驱动的数据结构和接口。
  6. Android.mk: 创建了红外服务的 Makefile 文件,用于编译红外服务的 APK 文件和库文件。
  7. IrrxService.apk: 添加了红外服务的 APK 文件,这是一个 Android 应用,用于接收红外驱动的按键事件,并将其转发给其他应用。
  8. libserial_port.so: 添加了红外服务的库文件,这个库提供了串口通信的功能,用于接收红外信号。
  9. 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 bytes
 9 files changed, 299 insertions(+)
 create mode 100755 kernel-3.10/drivers/misc/mediatek/ir/Makefile
 create mode 100755 kernel-3.10/drivers/misc/mediatek/ir/irrx.c
 create mode 100755 kernel-3.10/drivers/misc/mediatek/ir/irrx.h
 create mode 100755 packages/apps/IrrxService/Android.mk
 create mode 100755 packages/apps/IrrxService/IrrxService.apk
 create mode 100755 packages/apps/IrrxService/libs/arm/libserial_port.so
 create mode 100755 packages/apps/IrrxService/libs/arm64/libserial_port.so
 
diff --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 += UsbCamera
 PRODUCT_PACKAGES += HdmiIn4a90
 PRODUCT_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 @@ endif
 obj-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


相关文章
|
11月前
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
1068 4
|
3月前
|
监控 Android开发 数据安全/隐私保护
批量发送短信的平台,安卓群发短信工具插件脚本,批量群发短信软件【autojs版】
这个Auto.js脚本实现了完整的批量短信发送功能,包含联系人管理、短信内容编辑、发送状态监控等功能
|
3月前
|
API Android开发 数据安全/隐私保护
|
7月前
|
存储 编解码 监控
Android平台GB28181执法记录仪技术方案与实现
本文介绍了大牛直播SDK的SmartGBD在执法记录仪场景中的应用。GB28181协议作为视频监控联网的国家标准,为设备互联互通提供规范。SmartGBD专为Android平台设计,支持音视频采集、编码与传输,具备自适应算法和多功能扩展优势。文章分析了执法记录仪的需求,如实时音视频传输、设备管理及数据安全,并详细阐述了基于SmartGBD的技术实现方案,包括环境准备、SDK集成、设备注册、音视频处理及功能扩展等步骤。最后展望了SmartGBD在未来智慧物联领域的广阔应用前景。
312 13
|
7月前
|
存储 编解码 开发工具
Android平台毫秒级低延迟HTTP-FLV直播播放器技术探究与实现
本文详细探讨了在Android平台上实现HTTP-FLV播放器的过程。首先介绍了FLV格式的基础,包括文件头和标签结构。接着分析了HTTP-FLV传输原理,通过分块传输实现流畅播放。然后重点讲解了播放器的实现步骤,涵盖网络请求、数据解析、音视频解码与渲染,以及播放控制功能的设计。文章还讨论了性能优化和网络异常处理的方法,并总结了HTTP-FLV播放器的技术价值,尤其是在特定场景下的应用意义。
301 11
|
7月前
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
|
10月前
|
IDE 开发工具 Android开发
移动应用开发之旅:探索Android和iOS平台
在这篇文章中,我们将深入探讨移动应用开发的两个主要平台——Android和iOS。我们将了解它们的操作系统、开发环境和工具,并通过代码示例展示如何在这两个平台上创建一个简单的“Hello World”应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧,帮助你更好地理解和掌握移动应用开发。
256 17
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
400 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
3天前
|
移动开发 JavaScript 应用服务中间件
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
45 5
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
9天前
|
移动开发 前端开发 Android开发
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
174 12
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡