2014-04-03 20:34:28 -03:00
rc-core-objs := rc-main.o rc-ir-raw.o
2009-12-11 08:00:00 -03:00
2010-04-02 20:01:00 -03:00
obj-y += keymaps/
2010-11-17 13:28:38 -03:00
obj-$(CONFIG_RC_CORE) += rc-core.o
2010-07-03 01:06:57 -03:00
obj-$(CONFIG_LIRC) += lirc_dev.o
2010-03-24 20:47:53 -03:00
obj-$(CONFIG_IR_NEC_DECODER) += ir-nec-decoder.o
2010-04-04 10:27:20 -03:00
obj-$(CONFIG_IR_RC5_DECODER) += ir-rc5-decoder.o
2010-04-08 20:04:40 -03:00
obj-$(CONFIG_IR_RC6_DECODER) += ir-rc6-decoder.o
2010-04-15 18:46:05 -03:00
obj-$(CONFIG_IR_JVC_DECODER) += ir-jvc-decoder.o
2010-04-15 18:46:10 -03:00
obj-$(CONFIG_IR_SONY_DECODER) += ir-sony-decoder.o
2011-11-23 12:04:08 -03:00
obj-$(CONFIG_IR_SANYO_DECODER) += ir-sanyo-decoder.o
2014-01-17 10:58:48 -03:00
obj-$(CONFIG_IR_SHARP_DECODER) += ir-sharp-decoder.o
[media] rc-core support for Microsoft IR keyboard/mouse
This is a custom IR protocol decoder, for the RC-6-ish protocol used by
the Microsoft Remote Keyboard, apparently developed internally at
Microsoft, and officially dubbed MCIR-2, per their March 2011 remote and
transceiver requirements and specifications document, which also touches
on this IR keyboard/mouse device.
Its a standard keyboard with embedded thumb stick mouse pointer and
mouse buttons, along with a number of media keys. The media keys are
standard RC-6, identical to the signals from the stock MCE remotes, and
will be handled as such. The keyboard and mouse signals will be decoded
and delivered to the system by an input device registered specifically
by this driver.
Successfully tested with multiple mceusb-driven transceivers, as well as
with fintek-cir and redrat3 hardware. Essentially, any raw IR hardware
with enough sampling resolution should be able to use this decoder,
nothing about it is at all receiver-hardware-specific.
This work is inspired by lirc_mod_mce:
The documentation there and code aided in understanding and decoding the
protocol, but the bulk of the code is actually borrowed more from the
existing in-kernel decoders than anything. I did recycle the keyboard
keycode table, a few defines, and some of the keyboard and mouse data
parsing bits from lirc_mod_mce though.
Special thanks to James Meyer for providing the hardware, and being
patient with me as I took forever to get around to writing this.
callback routine to ensure we don't get any stuck keys, and used
symbolic names for the keytable. Also cc'ing Florian this time, who I
believe is the original mod-mce author...
CC: Florian Demski <fdemski@users.sourceforge.net>
Signed-off-by: Jarod Wilson <jarod@redhat.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2011-07-13 18:09:48 -03:00
obj-$(CONFIG_IR_MCE_KBD_DECODER) += ir-mce_kbd-decoder.o
2010-07-03 01:07:53 -03:00
obj-$(CONFIG_IR_LIRC_CODEC) += ir-lirc-codec.o
2014-07-26 17:28:26 -03:00
obj-$(CONFIG_IR_XMP_DECODER) += ir-xmp-decoder.o
2010-04-16 18:29:02 -03:00
# stand-alone IR receivers/transmitters
2011-08-06 18:18:07 -03:00
obj-$(CONFIG_RC_ATI_REMOTE) += ati_remote.o
2014-08-30 23:39:10 -03:00
obj-$(CONFIG_IR_HIX5HD2) += ir-hix5hd2.o
2010-04-16 18:29:02 -03:00
obj-$(CONFIG_IR_IMON) += imon.o
2011-03-16 17:14:52 -03:00
obj-$(CONFIG_IR_ITE_CIR) += ite-cir.o
2010-06-01 17:32:08 -03:00
obj-$(CONFIG_IR_MCEUSB) += mceusb.o
[media] fintek-cir: new driver for Fintek LPC SuperIO CIR function
This is a new driver for the Fintek LPC SuperIO CIR function, in the
Fintek F71809 chip. Hardware and datasheets were provided by Fintek, so
thanks go to them for supporting this effort.
This driver started out as a copy of the nuvoton-cir driver, and was
then modified as needed for the Fintek chip. The two share many
similaries, though the buffer handling for the Fintek chip is actually
nearly identical to the mceusb buffer handling, so the parser routine is
almost a drop-in copy of the mceusb buffer parser (a candidate for being
abstracted out into shared code at some point).
This initial code drop *only* supports receive, but the hardware does
support transmit as well. I really haven't even started to look at
what's required, but my guess is that its also pretty similar to mceusb.
Most people are probably only really interested in RX anyway though, so
I think its good to get this out there even with only RX.
(Nb: there are also Fintek-made mceusb receivers, which presumably, this
chip shares CIR hardware with).
This hardware can be found on at least Jetway NC98 boards and derivative
systems, and likely others as well. Functionality was tested with an
NC98 development board, in-kernel decode of RC6 (mce), RC5 (hauppauge)
and NEC-ish (tivo) remotes all successful, as was lirc userspace decode
of the RC6 remote.
CC: Aaron Huang <aaron_huang@fintek.com.tw>
CC: Tom Tsai <tom_tsai@fintek.com.tw>
Signed-off-by: Jarod Wilson <jarod@redhat.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2011-05-25 13:35:13 -03:00
obj-$(CONFIG_IR_FINTEK) += fintek-cir.o
2014-11-18 17:22:34 -03:00
obj-$(CONFIG_IR_MESON) += meson-ir.o
[media] IR: add driver for Nuvoton w836x7hg integrated CIR
This is a new ir-core pnp driver for the Nuvoton w836x7hg integrated CIR
function. The chip is found on at least the ASRock ION 330HT boxes and
apparently, on a number of Intel DP55-series motherboards:
http://www.asrock.com/nettop/overview.asp?Model=ION%20330HT
http://downloadcenter.intel.com/Detail_Desc.aspx?agr=Y&DwnldID=17685&lang=eng
This driver was made possible by a hardware donation from Nuvoton, along
with sample code (in the form of an lirc driver) and datasheet, so huge
thanks to them for supporting this effort. Note that this driver
constitutes a massive rewrite, porting from the lirc interfaces to the
ir-core interfaces, and restructuring the driver to look more like Maxim
Levitsky's ene_ir driver (as well as generally making it look more like
kernel code).
There's some work left to be done on this driver, to fully support the
range of functionality possible, but receive and IR power-on/wake are
both functional (may require setting wake key under another OS atm). The
hardware I've got (one of the ASRock boxes) only supports RX, so TX is
completely untested as of yet. Certain RX parameters, like sample
resolution and RX IRQ sample length trigger level could possibly stand
to be made tweakable via modparams or sysfs nodes, but the current
values work well enough for me w/an MCE RC6A remote.
The original lirc driver carried support for the Windows MCE IR
keyboard/mouse device, which I plan to add back generically, in a way
that should be usable by any raw IR receiver (or at least by this driver
and the mceusb driver).
Suspend and resume have also been tested, the power button on my remote
can be used to wake the machine, and CIR functionality resumes just
fine. Module unload/reload has also been tested, though not extensively
or repetitively. Also tested to work with the lirc bridge plugin for
userspace decoding.
Signed-off-by: Jarod Wilson <jarod@redhat.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2010-10-07 17:50:34 -03:00
obj-$(CONFIG_IR_NUVOTON) += nuvoton-cir.o
2010-07-31 11:59:26 -03:00
obj-$(CONFIG_IR_ENE) += ene_ir.o
[media] redrat3: new rc-core IR transceiver device driver
This is a new rc-core device driver for the IR transceivers made by
RedRat Ltd. (http://redrat.co.uk/). It started out life as an
out-of-lirc-tree lirc driver, maintained in its own repo on sourceforge,
by Stephen Cox. He started porting it to what was then ir-core, and I
finally picked it up about two week ago and did a fairly large overhaul
on it, and its now into a state where I'm fairly comfortable submitting
it here for review and inclusion in the kernel. I'm claiming authorship
of this driver, since while it started out as Stephen's work, its
definitely a derivative work now, at 876 lines added and 1698 lines
removed since grabbing it from sourceforge. Stephen's name is retained
as secondary author though, and credited in the headers. Those
interested in seeing how the changes evolved can (at least for now) look
at this branch in my git tree:
http://git.kernel.org/?p=linux/kernel/git/jarod/linux-2.6-ir.git;a=shortlog;h=refs/heads/redrat3
That won't be around forever though, and I'm doing this as a single
commit to go into mainline. Anyway...
I've successfully tested in-kernel decode of rc5, rc6 and nec remotes,
as well as lirc userspace decode of rc5 and rc6. There are still some
quirks here to sort out with rc5 lirc userspace decode, but I'm working
with the RedRat folks themselves to figure out what's going on there
(rc5 lirc decode works, but you only get an event on key release --
in-kernel rc5 decode behaves perfectly fine). Note that lirc decode of
rc6 is working perfectly. Transmit is also working, tested by pointing
the redrat3 at an mceusb transceiver, which happily picked up the
transmitted signals and properly decoded them.
There's no default remote for this hardware, so its somewhat arbitrarily
set to use the Hauppauge RC5 keymap by default. Easily changed out by
way of ir-keytable and irrelevant if you're using lircd for decode.
CC: Chris Dodge <chris@redrat.co.uk>
CC: Andrew Vincer <Andrew.Vincer@redrat.co.uk>
CC: Stephen Cox <scox_nz@yahoo.com>
Signed-off-by: Jarod Wilson <jarod@redhat.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2011-05-04 14:02:42 -03:00
obj-$(CONFIG_IR_REDRAT3) += redrat3.o
2012-08-10 06:16:36 -03:00
obj-$(CONFIG_IR_RX51) += ir-rx51.o
[media] rc: add support for IR LEDs driven through SPI
The ir-spi is a simple device driver which supports the
connection between an IR LED and the MOSI line of an SPI device.
The driver, indeed, uses the SPI framework to stream the raw data
provided by userspace through an rc character device. The chardev
is handled by the LIRC framework and its functionality basically
provides:
- write: the driver gets a pulse/space signal and translates it
to a binary signal that will be streamed to the IR led through
the SPI framework.
- set frequency: sets the frequency whith which the data should
be sent. This is handle with ioctl with the
LIRC_SET_SEND_CARRIER flag (as per lirc documentation)
- set duty cycle: this is also handled with ioctl with the
LIRC_SET_SEND_DUTY_CYCLE flag. The driver handles duty cycles
of 50%, 60%, 70%, 75%, 80% and 90%, calculated on 16bit data.
The character device is created under /dev/lircX name, where X is
and ID assigned by the LIRC framework.
Example of usage:
fd = open("/dev/lirc0", O_RDWR);
if (fd < 0)
return -1;
val = 608000;
ret = ioctl(fd, LIRC_SET_SEND_CARRIER, &val);
if (ret < 0)
return -1;
val = 60;
ret = ioctl(fd, LIRC_SET_SEND_DUTY_CYCLE, &val);
if (ret < 0)
return -1;
n = write(fd, buffer, BUF_LEN);
if (n < 0 || n != BUF_LEN)
ret = -1;
close(fd);
Signed-off-by: Andi Shyti <andi.shyti@samsung.com>
Signed-off-by: Sean Young <sean@mess.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
2016-12-16 04:12:18 -02:00
obj-$(CONFIG_IR_SPI) += ir-spi.o
2010-08-02 15:46:03 -03:00
obj-$(CONFIG_IR_STREAMZAP) += streamzap.o
2010-10-29 16:08:28 -03:00
obj-$(CONFIG_IR_WINBOND_CIR) += winbond-cir.o
2010-11-25 18:36:27 -03:00
obj-$(CONFIG_RC_LOOPBACK) += rc-loopback.o
2012-02-28 01:51:40 -03:00
obj-$(CONFIG_IR_GPIO_CIR) += gpio-ir-recv.o
2017-07-07 05:51:59 -04:00
obj-$(CONFIG_IR_GPIO_TX) += gpio-ir-tx.o
2017-07-07 05:52:02 -04:00
obj-$(CONFIG_IR_PWM_TX) += pwm-ir-tx.o
2014-10-23 17:58:22 -03:00
obj-$(CONFIG_IR_IGORPLUGUSB) += igorplugusb.o
2012-07-15 13:31:00 -03:00
obj-$(CONFIG_IR_IGUANA) += iguanair.o
2012-08-13 08:59:46 -03:00
obj-$(CONFIG_IR_TTUSBIR) += ttusbir.o
2013-10-18 06:01:14 -03:00
obj-$(CONFIG_RC_ST) += st_rc.o
2014-06-08 15:08:10 -03:00
obj-$(CONFIG_IR_SUNXI) += sunxi-cir.o
2014-02-28 20:28:55 -03:00
obj-$(CONFIG_IR_IMG) += img-ir/
2016-11-21 19:55:53 -02:00
obj-$(CONFIG_IR_SERIAL) += serial_ir.o
2017-03-07 17:07:59 -03:00
obj-$(CONFIG_IR_SIR) += sir_ir.o
2017-01-13 05:35:39 -02:00
obj-$(CONFIG_IR_MTK) += mtk-cir.o
2017-07-30 09:23:13 -04:00
obj-$(CONFIG_IR_ZX) += zx-irdec.o