Commit 727f9b48 authored by Oskari Saarenmaa's avatar Oskari Saarenmaa Committed by Dmitry Torokhov

Input: sentelic - improve packet debugging information

Signed-off-by: default avatarOskari Saarenmaa <os@ohmu.fi>
Signed-off-by: default avatarTai-hwa Liang <avatar@sentelic.com>
Signed-off-by: default avatarDmitry Torokhov <dtor@mail.ru>
parent 7b85f73d
...@@ -37,6 +37,9 @@ ...@@ -37,6 +37,9 @@
#define FSP_CMD_TIMEOUT 200 #define FSP_CMD_TIMEOUT 200
#define FSP_CMD_TIMEOUT2 30 #define FSP_CMD_TIMEOUT2 30
#define GET_ABS_X(packet) ((packet[1] << 2) | ((packet[3] >> 2) & 0x03))
#define GET_ABS_Y(packet) ((packet[2] << 2) | (packet[3] & 0x03))
/** Driver version. */ /** Driver version. */
static const char fsp_drv_ver[] = "1.0.0-K"; static const char fsp_drv_ver[] = "1.0.0-K";
...@@ -620,17 +623,39 @@ static struct attribute_group fsp_attribute_group = { ...@@ -620,17 +623,39 @@ static struct attribute_group fsp_attribute_group = {
}; };
#ifdef FSP_DEBUG #ifdef FSP_DEBUG
static void fsp_packet_debug(unsigned char packet[]) static void fsp_packet_debug(struct psmouse *psmouse, unsigned char packet[])
{ {
static unsigned int ps2_packet_cnt; static unsigned int ps2_packet_cnt;
static unsigned int ps2_last_second; static unsigned int ps2_last_second;
unsigned int jiffies_msec; unsigned int jiffies_msec;
const char *packet_type = "UNKNOWN";
unsigned short abs_x = 0, abs_y = 0;
/* Interpret & dump the packet data. */
switch (packet[0] >> FSP_PKT_TYPE_SHIFT) {
case FSP_PKT_TYPE_ABS:
packet_type = "Absolute";
abs_x = GET_ABS_X(packet);
abs_y = GET_ABS_Y(packet);
break;
case FSP_PKT_TYPE_NORMAL:
packet_type = "Normal";
break;
case FSP_PKT_TYPE_NOTIFY:
packet_type = "Notify";
break;
case FSP_PKT_TYPE_NORMAL_OPC:
packet_type = "Normal-OPC";
break;
}
ps2_packet_cnt++; ps2_packet_cnt++;
jiffies_msec = jiffies_to_msecs(jiffies); jiffies_msec = jiffies_to_msecs(jiffies);
psmouse_dbg(psmouse, psmouse_dbg(psmouse,
"%08dms PS/2 packets: %02x, %02x, %02x, %02x\n", "%08dms %s packets: %02x, %02x, %02x, %02x; "
jiffies_msec, packet[0], packet[1], packet[2], packet[3]); "abs_x: %d, abs_y: %d\n",
jiffies_msec, packet_type,
packet[0], packet[1], packet[2], packet[3], abs_x, abs_y);
if (jiffies_msec - ps2_last_second > 1000) { if (jiffies_msec - ps2_last_second > 1000) {
psmouse_dbg(psmouse, "PS/2 packets/sec = %d\n", ps2_packet_cnt); psmouse_dbg(psmouse, "PS/2 packets/sec = %d\n", ps2_packet_cnt);
...@@ -639,7 +664,7 @@ static void fsp_packet_debug(unsigned char packet[]) ...@@ -639,7 +664,7 @@ static void fsp_packet_debug(unsigned char packet[])
} }
} }
#else #else
static void fsp_packet_debug(unsigned char packet[]) static void fsp_packet_debug(struct psmouse *psmouse, unsigned char packet[])
{ {
} }
#endif #endif
...@@ -671,10 +696,12 @@ static psmouse_ret_t fsp_process_byte(struct psmouse *psmouse) ...@@ -671,10 +696,12 @@ static psmouse_ret_t fsp_process_byte(struct psmouse *psmouse)
* Full packet accumulated, process it * Full packet accumulated, process it
*/ */
fsp_packet_debug(psmouse, packet);
switch (psmouse->packet[0] >> FSP_PKT_TYPE_SHIFT) { switch (psmouse->packet[0] >> FSP_PKT_TYPE_SHIFT) {
case FSP_PKT_TYPE_ABS: case FSP_PKT_TYPE_ABS:
abs_x = (packet[1] << 2) | ((packet[3] >> 2) & 0x03); abs_x = GET_ABS_X(packet);
abs_y = (packet[2] << 2) | (packet[3] & 0x03); abs_y = GET_ABS_Y(packet);
if (packet[0] & FSP_PB0_MFMC) { if (packet[0] & FSP_PB0_MFMC) {
/* /*
...@@ -785,8 +812,6 @@ static psmouse_ret_t fsp_process_byte(struct psmouse *psmouse) ...@@ -785,8 +812,6 @@ static psmouse_ret_t fsp_process_byte(struct psmouse *psmouse)
input_sync(dev); input_sync(dev);
fsp_packet_debug(packet);
return PSMOUSE_FULL_PACKET; return PSMOUSE_FULL_PACKET;
} }
......
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