NetBSD/sys/compat/darwin/darwin_iohidsystem.h
manu f9c483a301 Some initial support for IOHIDSystem. This gives us some pointer moves in X11
(not really related the the actual mouse movement, but this will come).

The darwin_iohidsystem_thread reads events from wscons, translates them
into IOHIDSystem events and wakes up the userland client with a notification.
To do this, I had to improve the void implementation of
io_connect_set_notification_port() to actually register something (I assumed
a single notification port, which makes some sense since only one process
seems to be able to open the driver)

Missing bits:
- we do not take event masks given by the process into account.
- the notification message has not been checked against Darwin
- events are badly translated
2003-09-11 23:16:18 +00:00

284 lines
7.9 KiB
C

/* $NetBSD: darwin_iohidsystem.h,v 1.7 2003/09/11 23:16:19 manu Exp $ */
/*-
* Copyright (c) 2003 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
* by Emmanuel Dreyfus
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed by the NetBSD
* Foundation, Inc. and its contributors.
* 4. Neither the name of The NetBSD Foundation nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef _DARWIN_IOHIDSYSTEM_H_
#define _DARWIN_IOHIDSYSTEM_H_
extern struct mach_iokit_devclass darwin_iohidsystem_devclass;
/* Events and event queue */
#define DARWIN_NX_NULLEVENT 0
#define DARWIN_NX_LMOUSEDOWN 1
#define DARWIN_NX_LMOUSEUP 2
#define DARWIN_NX_RMOUSEDOWN 3
#define DARWIN_NX_RMOUSEUP 4
#define DARWIN_NX_MOUSEMOVED 5
#define DARWIN_NX_LMOUSEDRAGGED 6
#define DARWIN_NX_RMOUSEDRAGGED 7
#define DARWIN_NX_MOUSEENTERED 8
#define DARWIN_NX_MOUSEEXITED 9
#define DARWIN_NX_KEYDOWN 10
#define DARWIN_NX_KEYUP 11
#define DARWIN_NX_FLAGSCHANGED 12
#define DARWIN_NX_LMOUSEDOWN_MASK (1 << DARWIN_NX_LMOUSEDOWN)
#define DARWIN_NX_LMOUSEUP_MASK (1 << DARWIN_NX_LMOUSEUP)
#define DARWIN_NX_RMOUSEDOWN_MASK (1 << DARWIN_NX_RMOUSEDOWN)
#define DARWIN_NX_RMOUSEUP_MASK (1 << DARWIN_NX_RMOUSEUP)
#define DARWIN_NX_MOUSEMOVED_MASK (1 << DARWIN_NX_MOUSEMOVED)
#define DARWIN_NX_LMOUSEDRAGGED_MASK (1 << DARWIN_NX_LMOUSEDRAGGED)
#define DARWIN_NX_RMOUSEDRAGGED_MASK (1 << DARWIN_NX_RMOUSEDRAGGED)
#define DARWIN_NX_MOUSEENTERED_MASK (1 << DARWIN_NX_MOUSEENTERED)
#define DARWIN_NX_MOUSEEXITED_MASK (1 << DARWIN_NX_MOUSEEXITED)
#define DARWIN_NX_KEYDOWN_MASK (1 << DARWIN_NX_KEYDOWN)
#define DARWIN_NX_KEYUP_MASK (1 << DARWIN_NX_KEYUP)
#define DARWIN_NX_FLAGSCHANGED_MASK (1 << DARWIN_NX_FLAGSCHANGED)
typedef struct {
uint16_t tabletid;
uint16_t pointerid;
uint16_t deviceid;
uint16_t system_tabletid;
uint16_t vendor_pointertype;
uint32_t pointer_serialnum;
uint64_t uniqueid;
uint32_t cap_mask;
uint8_t ptrtype;
uint8_t enter_proximity;
int16_t reserved1;
} darwin_iohidsystem_tabletproxymity;
typedef struct {
int32_t x;
int32_t y;
int32_t z;
uint16_t buttons;
uint16_t pressure;
struct {
int16_t x;
int16_t y;
} tilt;
uint16_t rotation;
uint16_t tanpressure;
uint16_t devid;
uint16_t vendor1;
uint16_t vendor2;
uint16_t vendor3;
} darwin_iohidsystem_tabletpoint;
typedef union {
struct {
uint8_t subx;
uint8_t suby;
int16_t buttonid;
int32_t click;
uint8_t pressure;
uint8_t reserved1;
uint8_t subtype;
uint8_t reserved2;
uint32_t reserved3;
union {
darwin_iohidsystem_tabletpoint point;
darwin_iohidsystem_tabletproxymity proximity;
} tablet;
} mouse;
struct {
int32_t dx;
int32_t dy;
uint8_t subx;
uint8_t suby;
uint8_t subtype;
uint8_t reserved1;
int32_t reserved2;
union {
darwin_iohidsystem_tabletpoint point;
darwin_iohidsystem_tabletproxymity proximity;
} tablet;
} mouse_move;
struct {
uint16_t origi_charset;
int16_t repeat;
uint16_t charset;
uint16_t charcode;
uint16_t keycode;
uint16_t orig_charcode;
int32_t reserved1;
int32_t keyboardtype;
int32_t reserved2[7];
} key;
struct {
int16_t reserved;
int16_t eventnum;
int32_t trackingnum;
int32_t userdata;
int32_t reserved5[9];
} tracking;
struct {
int16_t da1;
int16_t da2;
int16_t da3;
int16_t reserved1;
int32_t reserved2[10];
} scrollwheel;
struct {
int16_t reserved;
int16_t subtype;
union {
float F[11];
long L[11];
short S[22];
char C[44];
} misc;
} compound;
struct {
int32_t x;
int32_t y;
int32_t z;
uint16_t buttons;
uint16_t pressure;
struct {
int16_t x;
int16_t y;
} tilt;
uint16_t rotation;
int16_t tanpressure;
uint16_t devid;
int16_t vendor1;
int16_t vendor2;
int16_t vendor3;
int32_t reserved[4];
} tablet;
struct {
uint16_t vendorid;
uint16_t tabletid;
uint16_t pointerid;
uint16_t deviceid;
uint16_t systemtabletid;
uint16_t vendor_pointertype;
uint32_t pointer_serialnum;
uint64_t uniqueid;
uint32_t cap_mask;
uint8_t ptr_type;
uint8_t enter_proximity;
int16_t reserved[9];
} proximity;
} darwin_iohidsystem_event_data;
typedef volatile struct {
int die_type;
int die_location_x;
int die_location_y;
unsigned long die_time_hi;
unsigned long die_time_lo;
int die_flags;
unsigned int die_window;
darwin_iohidsystem_event_data die_data;
} darwin_iohidsystem_event;
typedef struct {
int diei_next;
darwin_ev_lock_data_t diei_sem;
/*
* Avoid automatic alignement, this should be
* darwin_iohidsystem_event, we declare it as a char array.
*/
unsigned char diei_event[76];
} darwin_iohidsystem_event_item;
#define DARWIN_IOHIDSYSTEM_EVENTQUEUE_LEN 240
struct darwin_iohidsystem_evglobals {
darwin_ev_lock_data_t evg_cursor_sem;
int evg_event_head;
int evg_event_tail;
int evg_event_last;
int evg_uniq_mouseid;
int evg_buttons;
int evg_event_flags;
int evg_event_time;
darwin_iogpoint evg_cursor_loc;
int evg_cursor_frame;
darwin_iogbounds evg_all_screen;
darwin_iogbounds evg_mouse_rect;
int evg_version;
int evg_struct_size;
int evg_last_frame;
unsigned int evg_reserved1[31];
unsigned evg_reserved2:27;
unsigned evg_want_pressure:1;
unsigned evg_want_precision:1;
unsigned evg_dontwant_coalesce:1;
unsigned evg_dont_coalesce:1;
unsigned evg_mouserect_valid:1;
int evg_moved_mask;
int evg_lastevent_sent;
int evg_lastevent_consumed;
darwin_ev_lock_data_t evg_waitcursor_sem;
int evg_waitcursor;
char evg_waitcursor_timeout;
char evg_waitcursor_enabled;
char evg_globalwaitcursor_enabled;
int evg_waitcursor_threshold;
darwin_iohidsystem_event_item
evg_evqueue[DARWIN_IOHIDSYSTEM_EVENTQUEUE_LEN];
};
/* Shared memory between the IOHIDSystem driver and userland */
struct darwin_iohidsystem_shmem {
int dis_global_offset; /* Offset to global zone, usually 8 */
int dis_private_offset; /* Offset to private memory. Don't care. */
struct darwin_iohidsystem_evglobals dis_evglobals;
};
/* I/O selectors for io_connect_method_{scalar|struct}i_{scalar|struct}o */
#define DARWIN_IOHIDCREATESHMEM 0
#define DARWIN_IOHIDSETEVENTSENABLE 1
#define DARWIN_IOHIDSETCURSORENABLE 2
int darwin_iohidsystem_connect_method_scalari_scalaro(struct mach_trap_args *);
int darwin_iohidsystem_connect_map_memory(struct mach_trap_args *);
/* I/O notifications: XXX not checked on Darwin */
typedef struct {
mach_msg_header_t req_msgh;
mach_msg_trailer_t req_trailer;
} mach_notify_iohidsystem_request_t;
#endif /* _DARWIN_IOHIDSYSTEM_H_ */