Commit 58389982 authored by Sean Wang's avatar Sean Wang Committed by Mauro Carvalho Chehab

media: rc: mtk-cir: add support for MediaTek MT7622 SoC

This patch adds driver for CIR controller on MT7622 SoC. It has similar
handling logic as the previously MT7623 does, but there are some
differences in the register and field definition. So for ease portability
and maintenance, those differences all are being kept inside the platform
data as other drivers usually do. Currently testing successfully on NEC
and SONY remote controller.
Signed-off-by: default avatarSean Wang <sean.wang@mediatek.com>
Signed-off-by: default avatarSean Young <sean@mess.org>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
parent 50c3c1ba
...@@ -84,6 +84,13 @@ static const u32 mt7623_regs[] = { ...@@ -84,6 +84,13 @@ static const u32 mt7623_regs[] = {
[MTK_IRINT_CLR_REG] = 0xd0, [MTK_IRINT_CLR_REG] = 0xd0,
}; };
static const u32 mt7622_regs[] = {
[MTK_IRCLR_REG] = 0x18,
[MTK_CHKDATA_REG] = 0x30,
[MTK_IRINT_EN_REG] = 0x1c,
[MTK_IRINT_CLR_REG] = 0x20,
};
struct mtk_field_type { struct mtk_field_type {
u32 reg; u32 reg;
u8 offset; u8 offset;
...@@ -113,6 +120,11 @@ static const struct mtk_field_type mt7623_fields[] = { ...@@ -113,6 +120,11 @@ static const struct mtk_field_type mt7623_fields[] = {
[MTK_HW_PERIOD] = {0x10, 0, GENMASK(7, 0)}, [MTK_HW_PERIOD] = {0x10, 0, GENMASK(7, 0)},
}; };
static const struct mtk_field_type mt7622_fields[] = {
[MTK_CHK_PERIOD] = {0x24, 0, GENMASK(24, 0)},
[MTK_HW_PERIOD] = {0x10, 0, GENMASK(24, 0)},
};
/* /*
* struct mtk_ir - This is the main datasructure for holding the state * struct mtk_ir - This is the main datasructure for holding the state
* of the driver * of the driver
...@@ -268,8 +280,17 @@ static const struct mtk_ir_data mt7623_data = { ...@@ -268,8 +280,17 @@ static const struct mtk_ir_data mt7623_data = {
.div = 4, .div = 4,
}; };
static const struct mtk_ir_data mt7622_data = {
.regs = mt7622_regs,
.fields = mt7622_fields,
.ok_count = 0xf,
.hw_period = 0xffff,
.div = 32,
};
static const struct of_device_id mtk_ir_match[] = { static const struct of_device_id mtk_ir_match[] = {
{ .compatible = "mediatek,mt7623-cir", .data = &mt7623_data}, { .compatible = "mediatek,mt7623-cir", .data = &mt7623_data},
{ .compatible = "mediatek,mt7622-cir", .data = &mt7622_data},
{}, {},
}; };
MODULE_DEVICE_TABLE(of, mtk_ir_match); MODULE_DEVICE_TABLE(of, mtk_ir_match);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment