Lines Matching +full:edge +full:- +full:offset
1 // SPDX-License-Identifier: GPL-2.0-or-later
5 * serial_ir - Device driver that records pulse- and pause-lengths
6 * (space-lengths) between DDCD event on a serial port.
8 * Copyright (C) 1996,97 Ralph Metzler <rjkm@thp.uni-koeln.de>
13 * Copyright (C) 2016 Sean Young <sean@mess.org> (port to rc-core)
27 #include <media/rc-core.h>
36 void (*send_pulse)(unsigned int length, ktime_t edge);
55 static int sense = -1; /* -1 = auto, 0 = active high, 1 = active low */
59 static void send_pulse_irdeo(unsigned int length, ktime_t edge);
62 static void send_pulse_homebrew(unsigned int length, ktime_t edge);
140 /* fetch serial input packet (1 byte) from register offset */
141 static u8 sinp(int offset) in sinp() argument
144 /* the register is memory-mapped */ in sinp()
145 offset <<= ioshift; in sinp()
147 return inb(io + offset); in sinp()
150 /* write serial output packet (1 byte) of value to register offset */
151 static void soutp(int offset, u8 value) in soutp() argument
154 /* the register is memory-mapped */ in soutp()
155 offset <<= ioshift; in soutp()
157 outb(value, io + offset); in soutp()
189 for (i = 0, output = 0x7f; rawbits > 0; rawbits -= 3) { in send_pulse_irdeo()
214 static void send_pulse_homebrew_softcarrier(unsigned int length, ktime_t edge) in send_pulse_homebrew_softcarrier() argument
216 ktime_t now, target = ktime_add_us(edge, length); in send_pulse_homebrew_softcarrier()
227 space = DIV_ROUND_CLOSEST((100 - serial_ir.duty_cycle) * in send_pulse_homebrew_softcarrier()
235 edge = ktime_add_ns(edge, pulse); in send_pulse_homebrew_softcarrier()
236 delta = ktime_to_ns(ktime_sub(edge, now)); in send_pulse_homebrew_softcarrier()
243 edge = ktime_add_ns(edge, space); in send_pulse_homebrew_softcarrier()
244 delta = ktime_to_ns(ktime_sub(edge, now)); in send_pulse_homebrew_softcarrier()
250 static void send_pulse_homebrew(unsigned int length, ktime_t edge) in send_pulse_homebrew() argument
253 send_pulse_homebrew_softcarrier(length, edge); in send_pulse_homebrew()
326 static int last_dcd = -1; in serial_ir_irq_handler()
338 dev_err(&serial_ir.pdev->dev, "Trapped in interrupt"); in serial_ir_irq_handler()
342 sense != -1) { in serial_ir_irq_handler()
356 dev_dbg(&serial_ir.pdev->dev, in serial_ir_irq_handler()
368 dev_err(&serial_ir.pdev->dev, in serial_ir_irq_handler()
388 jiffies + usecs_to_jiffies(serial_ir.rcdev->timeout)); in serial_ir_irq_handler()
418 return -ENODEV; in hardware_init_port()
469 .duration = serial_ir.rcdev->timeout in serial_ir_timeout()
488 rcdev = devm_rc_allocate_device(&dev->dev, RC_DRIVER_IR_RAW); in serial_ir_probe()
490 return -ENOMEM; in serial_ir_probe()
493 rcdev->tx_ir = serial_ir_tx; in serial_ir_probe()
495 rcdev->s_tx_carrier = serial_ir_tx_carrier; in serial_ir_probe()
497 rcdev->s_tx_duty_cycle = serial_ir_tx_duty_cycle; in serial_ir_probe()
501 rcdev->device_name = "Serial IR type home-brew"; in serial_ir_probe()
504 rcdev->device_name = "Serial IR type IRdeo"; in serial_ir_probe()
507 rcdev->device_name = "Serial IR type IRdeo remote"; in serial_ir_probe()
510 rcdev->device_name = "Serial IR type AnimaX"; in serial_ir_probe()
513 rcdev->device_name = "Serial IR type IgorPlug"; in serial_ir_probe()
517 rcdev->input_phys = KBUILD_MODNAME "/input0"; in serial_ir_probe()
518 rcdev->input_id.bustype = BUS_HOST; in serial_ir_probe()
519 rcdev->input_id.vendor = 0x0001; in serial_ir_probe()
520 rcdev->input_id.product = 0x0001; in serial_ir_probe()
521 rcdev->input_id.version = 0x0100; in serial_ir_probe()
522 rcdev->open = serial_ir_open; in serial_ir_probe()
523 rcdev->close = serial_ir_close; in serial_ir_probe()
524 rcdev->dev.parent = &serial_ir.pdev->dev; in serial_ir_probe()
525 rcdev->allowed_protocols = RC_PROTO_BIT_ALL_IR_DECODER; in serial_ir_probe()
526 rcdev->driver_name = KBUILD_MODNAME; in serial_ir_probe()
527 rcdev->map_name = RC_MAP_RC6_MCE; in serial_ir_probe()
528 rcdev->min_timeout = 1; in serial_ir_probe()
529 rcdev->timeout = IR_DEFAULT_TIMEOUT; in serial_ir_probe()
530 rcdev->max_timeout = 10 * IR_DEFAULT_TIMEOUT; in serial_ir_probe()
531 rcdev->rx_resolution = 250; in serial_ir_probe()
537 result = devm_request_irq(&dev->dev, irq, serial_ir_irq_handler, in serial_ir_probe()
541 if (result == -EBUSY) in serial_ir_probe()
542 dev_err(&dev->dev, "IRQ %d busy\n", irq); in serial_ir_probe()
543 else if (result == -EINVAL) in serial_ir_probe()
544 dev_err(&dev->dev, "Bad irq number or handler\n"); in serial_ir_probe()
550 (devm_request_mem_region(&dev->dev, iommap, 8UL << ioshift, in serial_ir_probe()
552 (!iommap && (devm_request_region(&dev->dev, io, 8, in serial_ir_probe()
554 dev_err(&dev->dev, "port %04x already in use\n", io); in serial_ir_probe()
555 dev_warn(&dev->dev, "use 'setserial /dev/ttySX uart none'\n"); in serial_ir_probe()
556 dev_warn(&dev->dev, in serial_ir_probe()
558 dev_warn(&dev->dev, "make sure this module is loaded first\n"); in serial_ir_probe()
559 return -EBUSY; in serial_ir_probe()
571 if (sense == -1) { in serial_ir_probe()
589 dev_info(&dev->dev, "auto-detected active %s receiver\n", in serial_ir_probe()
592 dev_info(&dev->dev, "Manually using active %s receiver\n", in serial_ir_probe()
595 dev_dbg(&dev->dev, "Interrupt %d, port %04x obtained\n", irq, io); in serial_ir_probe()
597 return devm_rc_register_device(&dev->dev, rcdev); in serial_ir_probe()
638 ktime_t edge; in serial_ir_tx() local
648 edge = ktime_get(); in serial_ir_tx()
653 hardware[type].send_pulse(txbuf[i], edge); in serial_ir_tx()
655 edge = ktime_add_us(edge, txbuf[i]); in serial_ir_tx()
656 delta = ktime_us_delta(edge, ktime_get()); in serial_ir_tx()
659 usleep_range(delta - 25, delta + 25); in serial_ir_tx()
679 return -EINVAL; in serial_ir_tx_carrier()
743 result = -ENOMEM; in serial_ir_init()
779 return -EINVAL; in serial_ir_init_module()
791 /* make sure sense is either -1, 0, or 1 */ in serial_ir_init_module()
792 if (sense != -1) in serial_ir_init_module()
807 MODULE_DESCRIPTION("Infra-red receiver driver for serial ports.");
812 MODULE_PARM_DESC(type, "Hardware type (0 = home-brew, 1 = IRdeo, 2 = IRdeo Remote, 3 = AnimaX, 4 = …
824 * See linux-kernel/drivers/tty/serial/8250/8250.c serial_in()/out()
827 MODULE_PARM_DESC(ioshift, "shift I/O register offset (0 = no shift)");