Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 8f8be243 authored by Magnus Damm's avatar Magnus Damm Committed by Dmitry Torokhov
Browse files

Input: sh_keysc - update the driver with mode 6



Add mode 6 support to the sh_keysc driver. Also update the KYOUTDR mask
value to include all 16 register bits.

Signed-off-by: default avatarMagnus Damm <damm@opensource.se>
Signed-off-by: default avatarDmitry Torokhov <dtor@mail.ru>
parent 324e5ade
Loading
Loading
Loading
Loading
+2 −1
Original line number Original line Diff line number Diff line
@@ -31,6 +31,7 @@ static const struct {
	[SH_KEYSC_MODE_3] = { 2, 4, 7 },
	[SH_KEYSC_MODE_3] = { 2, 4, 7 },
	[SH_KEYSC_MODE_4] = { 3, 6, 6 },
	[SH_KEYSC_MODE_4] = { 3, 6, 6 },
	[SH_KEYSC_MODE_5] = { 4, 6, 7 },
	[SH_KEYSC_MODE_5] = { 4, 6, 7 },
	[SH_KEYSC_MODE_6] = { 5, 7, 7 },
};
};


struct sh_keysc_priv {
struct sh_keysc_priv {
@@ -109,7 +110,7 @@ static irqreturn_t sh_keysc_isr(int irq, void *dev_id)
			n = keyin_nr * i;
			n = keyin_nr * i;


			/* drive one KEYOUT pin low, read KEYIN pins */
			/* drive one KEYOUT pin low, read KEYIN pins */
			sh_keysc_write(priv, KYOUTDR, 0xfff ^ (3 << (i * 2)));
			sh_keysc_write(priv, KYOUTDR, 0xffff ^ (3 << (i * 2)));
			udelay(pdata->delay);
			udelay(pdata->delay);
			tmp = sh_keysc_read(priv, KYINDR);
			tmp = sh_keysc_read(priv, KYINDR);


+3 −3
Original line number Original line Diff line number Diff line
#ifndef __SH_KEYSC_H__
#ifndef __SH_KEYSC_H__
#define __SH_KEYSC_H__
#define __SH_KEYSC_H__


#define SH_KEYSC_MAXKEYS 42
#define SH_KEYSC_MAXKEYS 49


struct sh_keysc_info {
struct sh_keysc_info {
	enum { SH_KEYSC_MODE_1, SH_KEYSC_MODE_2, SH_KEYSC_MODE_3,
	enum { SH_KEYSC_MODE_1, SH_KEYSC_MODE_2, SH_KEYSC_MODE_3,
	       SH_KEYSC_MODE_4, SH_KEYSC_MODE_5 } mode;
	       SH_KEYSC_MODE_4, SH_KEYSC_MODE_5, SH_KEYSC_MODE_6 } mode;
	int scan_timing; /* 0 -> 7, see KYCR1, SCN[2:0] */
	int scan_timing; /* 0 -> 7, see KYCR1, SCN[2:0] */
	int delay;
	int delay;
	int kycr2_delay;
	int kycr2_delay;
	int keycodes[SH_KEYSC_MAXKEYS];
	int keycodes[SH_KEYSC_MAXKEYS]; /* KEYIN * KEYOUT */
};
};


#endif /* __SH_KEYSC_H__ */
#endif /* __SH_KEYSC_H__ */