1 | /**
|
---|
2 | * Copyright © 2009 Red Hat, Inc.
|
---|
3 | *
|
---|
4 | * Permission is hereby granted, free of charge, to any person obtaining a
|
---|
5 | * copy of this software and associated documentation files (the "Software"),
|
---|
6 | * to deal in the Software without restriction, including without limitation
|
---|
7 | * the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
---|
8 | * and/or sell copies of the Software, and to permit persons to whom the
|
---|
9 | * Software is furnished to do so, subject to the following conditions:
|
---|
10 | *
|
---|
11 | * The above copyright notice and this permission notice (including the next
|
---|
12 | * paragraph) shall be included in all copies or substantial portions of the
|
---|
13 | * Software.
|
---|
14 | *
|
---|
15 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
---|
16 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
---|
17 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
---|
18 | * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
---|
19 | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
---|
20 | * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
---|
21 | * DEALINGS IN THE SOFTWARE.
|
---|
22 | */
|
---|
23 |
|
---|
24 | #ifdef HAVE_DIX_CONFIG_H
|
---|
25 | #include <dix-config.h>
|
---|
26 | #endif
|
---|
27 |
|
---|
28 | #include "scrnintstr.h"
|
---|
29 | #include "windowstr.h"
|
---|
30 | #include "exevents.h"
|
---|
31 | #include <assert.h>
|
---|
32 |
|
---|
33 | #ifndef PROTOCOL_COMMON_H
|
---|
34 | #define PROTOCOL_COMMON_H
|
---|
35 |
|
---|
36 | extern int BadDevice;
|
---|
37 |
|
---|
38 | /* Check default values in a reply */
|
---|
39 | #define reply_check_defaults(rep, len, type) \
|
---|
40 | { \
|
---|
41 | assert((len) >= sz_x##type##Reply); \
|
---|
42 | assert((rep)->repType == X_Reply); \
|
---|
43 | assert((rep)->RepType == X_##type); \
|
---|
44 | assert((rep)->sequenceNumber == CLIENT_SEQUENCE); \
|
---|
45 | assert((rep)->length >= (sz_x##type##Reply - 32)/4); \
|
---|
46 | }
|
---|
47 |
|
---|
48 | /* initialise default values for request */
|
---|
49 | #define request_init(req, type) \
|
---|
50 | { \
|
---|
51 | (req)->reqType = 128; /* doesn't matter */ \
|
---|
52 | (req)->ReqType = X_##type; \
|
---|
53 | (req)->length = (sz_x##type##Req >> 2); \
|
---|
54 | }
|
---|
55 |
|
---|
56 |
|
---|
57 | /* Various defines used in the tests. Some tests may use different values
|
---|
58 | * than these defaults */
|
---|
59 | /* default client index */
|
---|
60 | #define CLIENT_INDEX 1
|
---|
61 | /* default client mask for resources and windows */
|
---|
62 | #define CLIENT_MASK ((CLIENT_INDEX) << CLIENTOFFSET)
|
---|
63 | /* default client sequence number for replies */
|
---|
64 | #define CLIENT_SEQUENCE 0x100
|
---|
65 | /* default root window id */
|
---|
66 | #define ROOT_WINDOW_ID 0x10
|
---|
67 | /* default client window id */
|
---|
68 | #define CLIENT_WINDOW_ID 0x100001
|
---|
69 | /* invalid window ID. use for BadWindow checks. */
|
---|
70 | #define INVALID_WINDOW_ID 0x111111
|
---|
71 | /* initial fake sprite position */
|
---|
72 | #define SPRITE_X 100
|
---|
73 | #define SPRITE_Y 200
|
---|
74 |
|
---|
75 |
|
---|
76 | /* Various structs used throughout the tests */
|
---|
77 |
|
---|
78 |
|
---|
79 | /* The default devices struct, contains one pointer + keyboard and the
|
---|
80 | * matching master devices. Initialize with init_devices() if needed. */
|
---|
81 | struct devices {
|
---|
82 | DeviceIntPtr vcp;
|
---|
83 | DeviceIntPtr vck;
|
---|
84 | DeviceIntPtr mouse;
|
---|
85 | DeviceIntPtr kbd;
|
---|
86 |
|
---|
87 | int num_devices;
|
---|
88 | int num_master_devices;
|
---|
89 | } devices;
|
---|
90 |
|
---|
91 | /**
|
---|
92 | * The set of default devices available in all tests if necessary.
|
---|
93 | */
|
---|
94 | extern struct devices devices;
|
---|
95 |
|
---|
96 | /**
|
---|
97 | * test-specific userdata, passed into the reply handler.
|
---|
98 | */
|
---|
99 | extern void *userdata;
|
---|
100 | /**
|
---|
101 | * The reply handler called from WriteToClient. Set this handler if you need
|
---|
102 | * to check the reply values.
|
---|
103 | */
|
---|
104 | void (*reply_handler)(ClientPtr client, int len, char *data, void *userdata);
|
---|
105 |
|
---|
106 | /**
|
---|
107 | * The default screen used for the windows. Initialized by init_simple().
|
---|
108 | */
|
---|
109 | extern ScreenRec screen;
|
---|
110 | /**
|
---|
111 | * Semi-initialized root window. initialized by init().
|
---|
112 | */
|
---|
113 | extern WindowRec root;
|
---|
114 | /**
|
---|
115 | * Semi-initialized top-level window. initialized by init().
|
---|
116 | */
|
---|
117 | extern WindowRec window;
|
---|
118 |
|
---|
119 | /* various simple functions for quick setup */
|
---|
120 | /**
|
---|
121 | * Initialize the above struct with default devices and return the struct.
|
---|
122 | * Usually not needed if you call ::init_simple.
|
---|
123 | */
|
---|
124 | struct devices init_devices(void);
|
---|
125 | /**
|
---|
126 | * Init a mostly zeroed out client with default values for index and mask.
|
---|
127 | */
|
---|
128 | ClientRec init_client(int request_len, void *request_data);
|
---|
129 | /**
|
---|
130 | * Init a mostly zeroed out window with the given window ID.
|
---|
131 | * Usually not needed if you call ::init_simple which sets up root and
|
---|
132 | * window.
|
---|
133 | */
|
---|
134 | void init_window(WindowPtr window, WindowPtr parent, int id);
|
---|
135 | /**
|
---|
136 | * Create a very simple setup that provides the minimum values for most
|
---|
137 | * tests, including a screen, the root and client window and the default
|
---|
138 | * device setup.
|
---|
139 | */
|
---|
140 | void init_simple(void);
|
---|
141 |
|
---|
142 | /* Declarations for various overrides in the test files. */
|
---|
143 | void __wrap_WriteToClient(ClientPtr client, int len, void *data);
|
---|
144 | int __wrap_XISetEventMask(DeviceIntPtr dev, WindowPtr win, int len, unsigned char* mask);
|
---|
145 | int __wrap_dixLookupWindow(WindowPtr *win, XID id, ClientPtr client, Mask access);
|
---|
146 | int __real_dixLookupWindow(WindowPtr *win, XID id, ClientPtr client, Mask access);
|
---|
147 | Bool __wrap_AddResource(XID id, RESTYPE type, pointer value);
|
---|
148 | int __wrap_dixLookupClient(ClientPtr *c, XID id, ClientPtr client, Mask access);
|
---|
149 | int __real_dixLookupClient(ClientPtr *c, XID id, ClientPtr client, Mask access);
|
---|
150 |
|
---|
151 |
|
---|
152 | #endif /* PROTOCOL_COMMON_H */
|
---|
153 |
|
---|