当前位置:首页 > 嵌入式 > 嵌入式硬件
[导读]1. 引言税收是国家财政的重要组成部分,但是在税收领域依法纳税意识淡薄,偷税逃税现象依然比较严重,尤其是对财务核算不健全的*,税务机关难以实施有效监控。这种现状不但

1. 引言

税收是国家财政的重要组成部分,但是在税收领域依法纳税意识淡薄,偷税逃税现象依然比较严重,尤其是对财务核算不健全的*,税务机关难以实施有效监控。这种现状不但严重扰乱正常的经济秩序,而且导致国家税收大量流失。为了进一步加强税源监控,堵塞税收漏洞,减少税收流失,国家先后出台了税控收款机标准GB18240.1~GB18240.6 等六个部分,建立了以电子收款机+税控器+税控IC 卡+税控收款机管理系统的基本工作模式,明确了以票控税的基本原则。要求每当电子收款机上完成一笔销售时,收集其销售明细数据,将其交由税控器记录统计,并将税控器依据销售明细数据生成的税控码添加到销售小票上,以此来表示此笔销售已被税务机关记录。本文所讨论的便是一种从电子收款机采集税源数据即销售明细数据的解决方案。

因为电子收款机使用的操作系统有很多种,对于不同操作系统采集税源数据的方案都有所不同。本文具体讨论Linux 操作系统下使用并口打印机的电子收款机的税源数据采集方案,使用串口打印机的情形亦可参照。Windows 操作系统下的采集方案请查阅参考文献。

2 方案设计

Linux 系统将打印机设备视为文件,通过对该文件的写操作来实现打印功能。通常情况下,对文件系统的监控是通过系统调用劫持来实现的。但是1) Linux 2.6 版本之后的内核,系统调用表的地址已经不能导出,系统调用劫持的实现难度加大;2) 劫持 sys_write 系统调用后,所有的文件写入操作都会被劫持,对系统的性能有较大影响;3) 修改后的打印数据必须存入销售软件进程的用户内存空间,才能调用文件驱动模块write 函数将其打印出来。而侵入销售软件进程将大大降低系统的独立性和可靠性。

基于以上考虑,选择了通过修改内核打印驱动模块来实现对电子收款机上销售小票打印数据的截获。

然而设备驱动运行于内核态,具有很大的局限性,如不能在终端上打印、不能做大延时的操作、不能使用C 的库函数等等,难以满足税源数据采集系统的功能需要。所以需要一个用户态的守护进程常驻内存,对内核态采集到的数据进行处理。

这样整个税源数据采集系统可以分为如下两个部分:

1)内核空间

在 Linux 并口打印驱动模块中增加一个拦截函数,替换原有的lp_write 函数,负责将打印数据发送给用户态的守护进程,并在收到守护进程返回的新的打印数据之后,将其打印出来。

2)用户空间

实现一个常驻内存的用户态守护进程,负责接收内核截取到的打印数据,并在进行处理后回送给内核。

3 关键实现技术

实现上述设计的关键在于解决“内核态与用户态的进程间通信”、“拦截并口打印驱动的write 操作”、“打印进程的阻塞及唤醒”三个问题。

3.1 内核态与用户态的进程间通信

本方案这种分为内核空间和用户空间两部分的结构设计,首先需要解决的就是内核态与用户态的进程间通信(interprocess communicatiON, IPC)。而在各种IPC 方法中,最适合此处设计需要的就是netlink socket 技术。

Netlink socket 最早出现于Linux 2.2 版的内核中,并在2. 4 版以后的版本中作为主要的内核与用户空间的通信方式而被广泛使用。相对于系统调用、ioctl 以及proc 文件系统等IPC方法而言,它具有简单易用、异步通信(适合大数据传输)、无编译依赖(可模块实现)、支持多播、支持内核发起会话等优点。其中“异步通信、无编译依赖、支持内核发起会话”

这三点正是本系统需要的关键特性,也是选用该技术的最主要原因。

Netlink socket 的通信依据是一个对应于进程的标识,一般定为该进程的ID。当通信的一端处于中断过程时,该标识为0。当使用netlink socket 进行通信,通信的双方都是用户态进程,则使用方法类似于消息队列。但通信双方有一端是中断过程,使用方法则不同。Netlinksocket 的最大特点是对中断过程的支持,它在内核空间接收用户空间数据时不再需要用户自行启动一个内核线程,而是通过另一个软中断调用用户事先指定的接收函数,这样就可以保证数据接收的实时性。

当 netlink socket 用于内核空间与用户空间的通信时,在用户空间的创建方法和一般套接字使用类似,但内核空间的创建方法则不同。在内核模块中使用 netlink_kernel_create()函数创建socket 时需要指明接收函数。之后用户空间进程创建socket,并将通信标识(一般是该进程的ID)发送到内核空间。这样内核空间获得了用户空间进程的通信标识后就可以进行通信了。

3.2 拦截并口打印驱动的write 操作

Linux 操作系统将设备看作文件,每个Linux 的设备驱动程序都定义了一个 file_operation结构,结构中的各个成员是驱动模块中定义函数的指针, 通过这些函数具体实现对文件的open, read, write 等操作。因此,只要将并口打印驱动模块的file_operation 结构常量——lp_fops的write 成员的值由lp_write 替换为指向拦截函数的指针就能实时地拦截并口打印机的打印操作。

这里需要实现两个关键函数:

1)lp_write_from_kernellp_write_from_kernel 函数实现内核空间的缓冲区数据的打印功能。来自守护进程的修改后打印数据是保存在内核空间的,因此不能调用原有的lp_write 函数进行打印。具体的实现可依照lp_write,只要将调用copy_from_user 函数的地方改为调用memcpy 函数即可。

2)lp_interceptlp_intercept 函数函数用于替换lp_write,拦截并口打印驱动的write 操作,实现打印数据截取与修改:当电子收款机的销售软件调用并口打印驱动的write 函数时,将写缓冲区的打印数据发送给守护进程;待守护进程返回修改后的打印数据(附加了税控码),调用lp_write_from_kernel 将其打印出来。

3.3 打印进程的阻塞及唤醒

当收到电子收款机的销售软件向并口打印机发出的打印请求时,内核态的并口打印模块需在将数据发送给用户态的守护进程之后阻塞打印请求进程。并且,当且仅当接收到守护进程的返回数据时,才会唤醒打印请求进程完成打印。

如何实现打印进程的阻塞及唤醒就是最后一个关键技术点。因为电子收款机只配备一个打印机、不需要复杂的互斥技术,所以只要使用“简单睡眠”就可以达到这个目标——通过使用下面的宏或函数:[!--empirenews.page--]

4 小结

本文详细说明了如何修改可加载的内核驱动模块实现并口打印数据的拦截与修改,如何运用netlink socket 技术实现内核与用户进程的通讯,以及进程的阻塞及唤醒技术。并在此基础上提出了一种利用上述技术实现的Linux 电子收款机税源数据采集方案。此方案在无需改变电子收款机原有设计架构的条件下,实现了税源数据采集及***税控码添加功能,经实际环境测试可行,符合对税源数据采集系统的整体要求。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

在嵌入式系统开发、调试和测试过程中,J-Link作为一种高效的调试工具,为开发者提供了极大的便利。然而,要想充分发挥J-Link的功能,首先需要正确安装其驱动程序。本文将详细介绍J-Link驱动的安装过程,并深入解析其中...

关键字: jlink 嵌入式系统 嵌入式开发

与谷歌的合作使 Nordic 能够在 nRF Connect SDK 中嵌入开发人员软件,以构建与安卓移动设备兼容的谷歌Find My Device和未知跟踪器警报服务

关键字: 谷歌 SoC 嵌入式开发

嵌入式开发作为当今电子工程和信息技术领域的核心分支,涵盖了广泛的软硬件技术和系统集成方法,用于构建高性能、低成本、低功耗、体积小巧且功能专一的嵌入式系统。这些系统无处不在,从微型传感器节点到复杂的工业控制设备,从日常使用...

关键字: 嵌入式开发 Python

嵌入式开发是当今信息技术领域不可或缺的一部分,它融合了硬件设计、软件开发和系统集成等多个学科,专门用于创建那些被嵌入到特定设备或系统中的专用计算机系统。嵌入式开发的主要过程包括利用分立元件或集成器件进行电路设计、结构设计...

关键字: 嵌入式开发 硬件设计 软件开发

嵌入式开发作为一种专业且技术密集型的领域,涵盖了从硬件底层驱动、中间件到应用层软件开发等多个层面的工作,其所需的工具种类繁多,各有针对性,旨在提升开发效率、保证代码质量以及简化调试过程。

关键字: 嵌入式开发 keil

嵌入式开发作为信息技术领域的重要分支,其涉及的语言种类繁多,各具特色。这些语言的选择取决于目标平台的特性、性能需求、开发者的熟练程度以及项目的具体要求。本文将详细介绍几种常见的嵌入式开发语言,包括C语言、C++、汇编语言...

关键字: 嵌入式开发 C语言

嵌入式开发是一项综合了硬件设计、软件编程以及系统整合的技术活动,其目的是为了创造出能够在特定环境中高效、稳定运行的嵌入式系统。这一流程涵盖了多个紧密关联且不可或缺的阶段,从最初的客户需求分析到最终的产品测试和交付,每个环...

关键字: 嵌入式开发 硬件设计

嵌入式开发作为一个融合了计算机软硬件和系统工程的综合性领域,其成功与否往往取决于三个核心要素的有效整合与协调。这三个要素分别是:硬件平台的选择与设计、软件开发及其优化、以及系统级的设计与集成。深入理解并熟练掌握这三个方面...

关键字: 嵌入式开发 ARM

嵌入式开发作为信息技术的关键支柱,在全球数字化转型浪潮中扮演着无可替代的角色。从传统的嵌入式微控制器到如今先进的片上系统(SoC),再到与云计算、人工智能深度融合的智能终端,嵌入式系统的演进与发展始终紧跟时代脉搏。本文将...

关键字: 嵌入式开发 智能应用

嵌入式开发是一种专门针对特定硬件平台设计和实现软件系统的工程实践,它涵盖了从需求分析、系统设计、编程实现、调试测试直到产品部署及维护的全过程。本文将深入探讨嵌入式开发的主要阶段,分解其流程并阐述每个步骤的关键要点,以便于...

关键字: 嵌入式开发 嵌入式软件
关闭
关闭