mirror of
https://github.com/torvalds/linux.git
synced 2024-12-13 14:43:03 +00:00
2874c5fd28
Based on 1 normalized pattern(s): 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 extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 3029 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190527070032.746973796@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
103 lines
2.2 KiB
C
103 lines
2.2 KiB
C
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
/*
|
|
* ImgTec IR Decoder setup for Sharp protocol.
|
|
*
|
|
* Copyright 2012-2014 Imagination Technologies Ltd.
|
|
*/
|
|
|
|
#include "img-ir-hw.h"
|
|
|
|
/* Convert Sharp data to a scancode */
|
|
static int img_ir_sharp_scancode(int len, u64 raw, u64 enabled_protocols,
|
|
struct img_ir_scancode_req *request)
|
|
{
|
|
unsigned int addr, cmd, exp, chk;
|
|
|
|
if (len != 15)
|
|
return -EINVAL;
|
|
|
|
addr = (raw >> 0) & 0x1f;
|
|
cmd = (raw >> 5) & 0xff;
|
|
exp = (raw >> 13) & 0x1;
|
|
chk = (raw >> 14) & 0x1;
|
|
|
|
/* validate data */
|
|
if (!exp)
|
|
return -EINVAL;
|
|
if (chk)
|
|
/* probably the second half of the message */
|
|
return -EINVAL;
|
|
|
|
request->protocol = RC_PROTO_SHARP;
|
|
request->scancode = addr << 8 | cmd;
|
|
return IMG_IR_SCANCODE;
|
|
}
|
|
|
|
/* Convert Sharp scancode to Sharp data filter */
|
|
static int img_ir_sharp_filter(const struct rc_scancode_filter *in,
|
|
struct img_ir_filter *out, u64 protocols)
|
|
{
|
|
unsigned int addr, cmd, exp = 0, chk = 0;
|
|
unsigned int addr_m, cmd_m, exp_m = 0, chk_m = 0;
|
|
|
|
addr = (in->data >> 8) & 0x1f;
|
|
addr_m = (in->mask >> 8) & 0x1f;
|
|
cmd = (in->data >> 0) & 0xff;
|
|
cmd_m = (in->mask >> 0) & 0xff;
|
|
if (cmd_m) {
|
|
/* if filtering commands, we can only match the first part */
|
|
exp = 1;
|
|
exp_m = 1;
|
|
chk = 0;
|
|
chk_m = 1;
|
|
}
|
|
|
|
out->data = addr |
|
|
cmd << 5 |
|
|
exp << 13 |
|
|
chk << 14;
|
|
out->mask = addr_m |
|
|
cmd_m << 5 |
|
|
exp_m << 13 |
|
|
chk_m << 14;
|
|
|
|
return 0;
|
|
}
|
|
|
|
/*
|
|
* Sharp decoder
|
|
* See also http://www.sbprojects.com/knowledge/ir/sharp.php
|
|
*/
|
|
struct img_ir_decoder img_ir_sharp = {
|
|
.type = RC_PROTO_BIT_SHARP,
|
|
.control = {
|
|
.decoden = 0,
|
|
.decodend2 = 1,
|
|
.code_type = IMG_IR_CODETYPE_PULSEDIST,
|
|
.d1validsel = 1,
|
|
},
|
|
/* main timings */
|
|
.tolerance = 20, /* 20% */
|
|
.timings = {
|
|
/* 0 symbol */
|
|
.s10 = {
|
|
.pulse = { 320 /* 320 us */ },
|
|
.space = { 680 /* 1 ms period */ },
|
|
},
|
|
/* 1 symbol */
|
|
.s11 = {
|
|
.pulse = { 320 /* 320 us */ },
|
|
.space = { 1680 /* 2 ms period */ },
|
|
},
|
|
/* free time */
|
|
.ft = {
|
|
.minlen = 15,
|
|
.maxlen = 15,
|
|
.ft_min = 5000, /* 5 ms */
|
|
},
|
|
},
|
|
/* scancode logic */
|
|
.scancode = img_ir_sharp_scancode,
|
|
.filter = img_ir_sharp_filter,
|
|
};
|