ms.c revision 1.5 1 1.5 plunky /* $NetBSD: ms.c,v 1.5 2006/11/12 19:00:43 plunky Exp $ */
2 1.1 tsutsui
3 1.1 tsutsui /*-
4 1.1 tsutsui * Copyright (c) 2001 Izumi Tsutsui. All rights reserved.
5 1.1 tsutsui * Copyright (c) 2000 Tsubai Masanari. All rights reserved.
6 1.1 tsutsui *
7 1.1 tsutsui * Redistribution and use in source and binary forms, with or without
8 1.1 tsutsui * modification, are permitted provided that the following conditions
9 1.1 tsutsui * are met:
10 1.1 tsutsui * 1. Redistributions of source code must retain the above copyright
11 1.1 tsutsui * notice, this list of conditions and the following disclaimer.
12 1.1 tsutsui * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 tsutsui * notice, this list of conditions and the following disclaimer in the
14 1.1 tsutsui * documentation and/or other materials provided with the distribution.
15 1.1 tsutsui * 3. The name of the author may not be used to endorse or promote products
16 1.1 tsutsui * derived from this software without specific prior written permission.
17 1.1 tsutsui *
18 1.1 tsutsui * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 1.1 tsutsui * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 1.1 tsutsui * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 1.1 tsutsui * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 1.1 tsutsui * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 1.1 tsutsui * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 1.1 tsutsui * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 1.1 tsutsui * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 1.1 tsutsui * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27 1.1 tsutsui * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 1.1 tsutsui */
29 1.2 lukem
30 1.2 lukem #include <sys/cdefs.h>
31 1.5 plunky __KERNEL_RCSID(0, "$NetBSD: ms.c,v 1.5 2006/11/12 19:00:43 plunky Exp $");
32 1.1 tsutsui
33 1.1 tsutsui #include <sys/param.h>
34 1.1 tsutsui #include <sys/device.h>
35 1.1 tsutsui #include <sys/systm.h>
36 1.1 tsutsui
37 1.1 tsutsui #include <dev/wscons/wsconsio.h>
38 1.1 tsutsui #include <dev/wscons/wsmousevar.h>
39 1.1 tsutsui
40 1.1 tsutsui #include <machine/cpu.h>
41 1.1 tsutsui #include <machine/bus.h>
42 1.1 tsutsui
43 1.1 tsutsui #include <news68k/dev/msvar.h>
44 1.1 tsutsui
45 1.1 tsutsui void
46 1.3 tsutsui ms_intr(struct ms_softc *sc)
47 1.1 tsutsui {
48 1.1 tsutsui bus_space_tag_t bt = sc->sc_bt;
49 1.1 tsutsui bus_space_handle_t bh = sc->sc_bh;
50 1.1 tsutsui bus_size_t offset = sc->sc_offset;
51 1.1 tsutsui int code, index, byte0, byte1, byte2;
52 1.1 tsutsui int button, dx, dy;
53 1.1 tsutsui
54 1.1 tsutsui if (sc->sc_wsmousedev == NULL)
55 1.1 tsutsui return;
56 1.1 tsutsui
57 1.1 tsutsui code = bus_space_read_1(bt, bh, offset);
58 1.1 tsutsui index = sc->sc_ndata;
59 1.1 tsutsui
60 1.1 tsutsui if (code & MS_S_MARK) {
61 1.1 tsutsui sc->sc_buf[MS_S_BYTE] = code;
62 1.1 tsutsui sc->sc_ndata = MS_X_BYTE;
63 1.1 tsutsui return;
64 1.1 tsutsui }
65 1.1 tsutsui
66 1.1 tsutsui if (index == MS_X_BYTE) {
67 1.1 tsutsui sc->sc_buf[MS_X_BYTE] = code;
68 1.1 tsutsui sc->sc_ndata = MS_Y_BYTE;
69 1.1 tsutsui return;
70 1.1 tsutsui }
71 1.1 tsutsui
72 1.1 tsutsui if (index == MS_Y_BYTE) {
73 1.1 tsutsui sc->sc_buf[MS_Y_BYTE] = code;
74 1.1 tsutsui sc->sc_ndata = 0;
75 1.1 tsutsui
76 1.1 tsutsui byte0 = sc->sc_buf[MS_S_BYTE];
77 1.1 tsutsui byte1 = sc->sc_buf[MS_X_BYTE];
78 1.1 tsutsui byte2 = sc->sc_buf[MS_Y_BYTE];
79 1.1 tsutsui
80 1.1 tsutsui button = 0;
81 1.1 tsutsui if (byte0 & MS_S_SW1)
82 1.1 tsutsui button |= 0x01;
83 1.1 tsutsui if (byte0 & MS_S_SW3)
84 1.1 tsutsui button |= 0x02;
85 1.1 tsutsui if (byte0 & MS_S_SW2)
86 1.1 tsutsui button |= 0x04;
87 1.1 tsutsui
88 1.1 tsutsui dx = byte1 & MS_X_DATA;
89 1.1 tsutsui if (byte0 & MS_S_XSIGN)
90 1.1 tsutsui dx = -dx;
91 1.1 tsutsui dy = byte2 & MS_Y_DATA;
92 1.1 tsutsui if (byte0 & MS_S_YSIGN)
93 1.1 tsutsui dy = -dy;
94 1.1 tsutsui
95 1.5 plunky wsmouse_input(sc->sc_wsmousedev,
96 1.5 plunky button,
97 1.5 plunky dx, -dy, 0, 0,
98 1.5 plunky WSMOUSE_INPUT_DELTA);
99 1.1 tsutsui }
100 1.1 tsutsui }
101