我在 Raspian jessie(无像素)(所有更新和升级)上安装了当前的 lirc 包(0.9.0~pre1-1.2)并连接到(lirc 默认)GPIO 端口:
- 到 gpio 端口 17 - 通过晶体管等的 IR LED
- 到 gpio 端口 18 - IR 接收器结节
接收器部分工作完美:
- mode2 命令从发送器接收原始数据
- 以前记录的键的 IR 代码识别有效
但是,IR LED 仅在不涉及 lirc 时才起作用:
- shell 脚本可以毫无问题地打开和关闭 IR LED
唯一不起作用的:
- irsend 不会使 IR 发射器发射任何东西,但是没有显示错误消息
所以硬件,尤其是 IR LED 肯定是在工作,而 lirc 不能让 LED 发出任何配置的 IR 代码。
请注意,这似乎与
不幸的是,事实并非如此。那里提供的“解决方案”是将/etc/modules 的数据放入文件/etc/modules-load.d/lirc_rpi.conf 中。我也试过了,但没什么区别。
任何帮助是极大的赞赏!
配置数据如下 - 如果需要任何其他数据,我很乐意添加它!蒂亚!
系统和 lirc 配置
提取自:/boot/config.txt
dtoverlay=lirc-rpi,gpio_in_pin=18,gpio_out_pin=17,debug=on
摘录:/etc/modules
lirc_dev
lirc_rpi gpio_in_pin=18 gpio_out_pin=17
(不确定这是否有必要,如果未配置,则没有什么区别!?任何提示都表示赞赏)
所有活动条目:/etc/lirc/hardware.conf
LIRCD_ARGS="--uinput"
DRIVER="default"
DEVICE="/dev/lirc0"
MODULES="lirc_rpi"
LIRCD_CONF=""
LIRCMD_CONF=""
一些系统输出
1) 加载驱动程序,启动后立即输出以下命令,输出: dmesg | grep lirc
lirc_dev: IR Remote Control driver registered, major 245
lirc_rpi: module is from the staging directory, the quality is unknown, you have been warned.
lirc_rpi: to_irq 178
lirc_rpi: auto-detected active low receiver on GPIO pin 18
lirc_rpi lirc_rpi: lirc_dev: driver lirc_rpi registered at minor = 0
lirc_rpi: driver registered!
input: lircd as /devices/virtual/input/input0
lirc_rpi: Interrupt 178 obtained
2)服务启动并运行,输出:systemctl status lirc
? lirc.service - LSB: Starts LIRC daemon.
Loaded: loaded (/etc/init.d/lirc)
Active: active (running) since Mo 2017-06-12 20:04:03 CEST; 2h 58min ago
Process: 377 ExecStart=/etc/init.d/lirc start (code=exited, status=0/SUCCESS)
CGroup: /system.slice/lirc.service
+-437 /usr/sbin/lircd --driver=default --device=/dev/lirc0 --uinput
3)加载模块,输出:lsmod | grep Module;lsmod | grep lirc
Module Size Used by
lirc_rpi 8453 3
lirc_dev 10211 1 lirc_rpi
rc_core 23776 1 lirc_dev
我按照http://aron.ws/projects/lirc_rpi/上的(过时的)手册中的故障排除步骤 来获取更多信息。
输出:cat /sys/kernel/debug/gpio
gpiochip0: GPIOs 0-53, parent: platform/20200000.gpio, pinctrl-bcm2835:
gpio-35 ( |? ) in hi
gpio-47 ( |? ) out lo
在这种情况下,我也看到了该输出:
这个用户和我一样被那个输出激怒了——有人能告诉我为什么这里列出了 gpio-35 和 gpio-47 吗?不应该是gpio-17和gpio-18吗?
输出:cat /proc/interrupts | grep lirc
178: 875 pinctrl-bcm2835 18 Edge lirc_rpi
这与获得中断 178 时的 dmesg 输出相匹配
lircd 的任何其他 dmesg 输出,无论采取什么操作,都是重复的(很可能是由于设置了调试选项)
lirc_rpi: SET_SEND_CARRIER
lirc_rpi: in init_timing_params, freq=38000 pulse=13157, space=13158
lirc_rpi: SET_SEND_DUTY_CYCLE
lirc_rpi: in init_timing_params, freq=38000 pulse=13157, space=13158