blob: 53f7e4d0f4b7d38376bcb77b9010c92887fd42e3 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#ifndef _LIBPS2_H
3#define _LIBPS2_H
4
5/*
6 * Copyright (C) 1999-2002 Vojtech Pavlik
7 * Copyright (C) 2004 Dmitry Torokhov
Linus Torvalds1da177e2005-04-16 15:20:36 -07008 */
9
Dmitry Torokhov3a92dd32018-01-04 11:27:05 -080010#include <linux/bitops.h>
Dmitry Torokhovb28bad62018-01-04 10:58:48 -080011#include <linux/mutex.h>
12#include <linux/types.h>
13#include <linux/wait.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070014
Dmitry Torokhov08be9542018-01-02 12:03:02 -080015#define PS2_CMD_SETSCALE11 0x00e6
16#define PS2_CMD_SETRES 0x10e8
Linus Torvalds1da177e2005-04-16 15:20:36 -070017#define PS2_CMD_GETID 0x02f2
18#define PS2_CMD_RESET_BAT 0x02ff
19
20#define PS2_RET_BAT 0xaa
21#define PS2_RET_ID 0x00
22#define PS2_RET_ACK 0xfa
23#define PS2_RET_NAK 0xfe
Dmitry Torokhova2d781f2008-11-19 17:02:24 -050024#define PS2_RET_ERR 0xfc
Linus Torvalds1da177e2005-04-16 15:20:36 -070025
Dmitry Torokhov3a92dd32018-01-04 11:27:05 -080026#define PS2_FLAG_ACK BIT(0) /* Waiting for ACK/NAK */
27#define PS2_FLAG_CMD BIT(1) /* Waiting for a command to finish */
28#define PS2_FLAG_CMD1 BIT(2) /* Waiting for the first byte of command response */
29#define PS2_FLAG_WAITID BIT(3) /* Command executing is GET ID */
30#define PS2_FLAG_NAK BIT(4) /* Last transmission was NAKed */
Dmitry Torokhov29acc422018-01-17 12:00:24 -080031#define PS2_FLAG_ACK_CMD BIT(5) /* Waiting to ACK the command (first) byte */
Linus Torvalds1da177e2005-04-16 15:20:36 -070032
33struct ps2dev {
34 struct serio *serio;
35
36 /* Ensures that only one command is executing at a time */
Arjan van de Venc4e32e92006-02-19 00:21:55 -050037 struct mutex cmd_mutex;
Linus Torvalds1da177e2005-04-16 15:20:36 -070038
39 /* Used to signal completion from interrupt handler */
40 wait_queue_head_t wait;
41
42 unsigned long flags;
Dmitry Torokhovb28bad62018-01-04 10:58:48 -080043 u8 cmdbuf[8];
44 u8 cmdcnt;
45 u8 nak;
Linus Torvalds1da177e2005-04-16 15:20:36 -070046};
47
48void ps2_init(struct ps2dev *ps2dev, struct serio *serio);
Dmitry Torokhovb28bad62018-01-04 10:58:48 -080049int ps2_sendbyte(struct ps2dev *ps2dev, u8 byte, unsigned int timeout);
50void ps2_drain(struct ps2dev *ps2dev, size_t maxbytes, unsigned int timeout);
Dmitry Torokhov181d6832009-09-16 01:06:43 -070051void ps2_begin_command(struct ps2dev *ps2dev);
52void ps2_end_command(struct ps2dev *ps2dev);
Dmitry Torokhovb28bad62018-01-04 10:58:48 -080053int __ps2_command(struct ps2dev *ps2dev, u8 *param, unsigned int command);
54int ps2_command(struct ps2dev *ps2dev, u8 *param, unsigned int command);
Dmitry Torokhov08be9542018-01-02 12:03:02 -080055int ps2_sliced_command(struct ps2dev *ps2dev, u8 command);
Dmitry Torokhovb28bad62018-01-04 10:58:48 -080056bool ps2_handle_ack(struct ps2dev *ps2dev, u8 data);
57bool ps2_handle_response(struct ps2dev *ps2dev, u8 data);
Linus Torvalds1da177e2005-04-16 15:20:36 -070058void ps2_cmd_aborted(struct ps2dev *ps2dev);
Dmitry Torokhovb28bad62018-01-04 10:58:48 -080059bool ps2_is_keyboard_id(u8 id);
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
61#endif /* _LIBPS2_H */