xref: /OK3568_Linux_fs/external/xserver/hw/xquartz/darwin.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /**************************************************************
2*4882a593Smuzhiyun  *
3*4882a593Smuzhiyun  * Xquartz initialization code
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * Copyright (c) 2007-2012 Apple Inc.
6*4882a593Smuzhiyun  * Copyright (c) 2001-2004 Torrey T. Lyons. All Rights Reserved.
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  * Permission is hereby granted, free of charge, to any person obtaining a
9*4882a593Smuzhiyun  * copy of this software and associated documentation files (the "Software"),
10*4882a593Smuzhiyun  * to deal in the Software without restriction, including without limitation
11*4882a593Smuzhiyun  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
12*4882a593Smuzhiyun  * and/or sell copies of the Software, and to permit persons to whom the
13*4882a593Smuzhiyun  * Software is furnished to do so, subject to the following conditions:
14*4882a593Smuzhiyun  *
15*4882a593Smuzhiyun  * The above copyright notice and this permission notice shall be included in
16*4882a593Smuzhiyun  * all copies or substantial portions of the Software.
17*4882a593Smuzhiyun  *
18*4882a593Smuzhiyun  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19*4882a593Smuzhiyun  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20*4882a593Smuzhiyun  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
21*4882a593Smuzhiyun  * THE ABOVE LISTED COPYRIGHT HOLDER(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
22*4882a593Smuzhiyun  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
23*4882a593Smuzhiyun  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
24*4882a593Smuzhiyun  * DEALINGS IN THE SOFTWARE.
25*4882a593Smuzhiyun  *
26*4882a593Smuzhiyun  * Except as contained in this notice, the name(s) of the above copyright
27*4882a593Smuzhiyun  * holders shall not be used in advertising or otherwise to promote the sale,
28*4882a593Smuzhiyun  * use or other dealings in this Software without prior written authorization.
29*4882a593Smuzhiyun  */
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun #ifdef HAVE_DIX_CONFIG_H
32*4882a593Smuzhiyun #include <dix-config.h>
33*4882a593Smuzhiyun #endif
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun #include <X11/X.h>
36*4882a593Smuzhiyun #include <X11/Xproto.h>
37*4882a593Smuzhiyun #include "os.h"
38*4882a593Smuzhiyun #include "servermd.h"
39*4882a593Smuzhiyun #include "inputstr.h"
40*4882a593Smuzhiyun #include "scrnintstr.h"
41*4882a593Smuzhiyun #include "mipointer.h"          // mi software cursor
42*4882a593Smuzhiyun #include "micmap.h"             // mi colormap code
43*4882a593Smuzhiyun #include "fb.h"                 // fb framebuffer code
44*4882a593Smuzhiyun #include "site.h"
45*4882a593Smuzhiyun #include "globals.h"
46*4882a593Smuzhiyun #include "dix.h"
47*4882a593Smuzhiyun #include "xkbsrv.h"
48*4882a593Smuzhiyun 
49*4882a593Smuzhiyun #include <X11/extensions/XI.h>
50*4882a593Smuzhiyun #include <X11/extensions/XIproto.h>
51*4882a593Smuzhiyun #include "exevents.h"
52*4882a593Smuzhiyun #include "extinit.h"
53*4882a593Smuzhiyun #include "glx_extinit.h"
54*4882a593Smuzhiyun #include "xserver-properties.h"
55*4882a593Smuzhiyun 
56*4882a593Smuzhiyun #include <sys/types.h>
57*4882a593Smuzhiyun #include <sys/time.h>
58*4882a593Smuzhiyun #include <sys/stat.h>
59*4882a593Smuzhiyun #include <sys/syslimits.h>
60*4882a593Smuzhiyun #include <stdio.h>
61*4882a593Smuzhiyun #include <fcntl.h>
62*4882a593Smuzhiyun #include <unistd.h>
63*4882a593Smuzhiyun #include <stdarg.h>
64*4882a593Smuzhiyun 
65*4882a593Smuzhiyun #define HAS_UTSNAME 1
66*4882a593Smuzhiyun #include <sys/utsname.h>
67*4882a593Smuzhiyun 
68*4882a593Smuzhiyun #define NO_CFPLUGIN
69*4882a593Smuzhiyun #include <IOKit/hidsystem/IOHIDLib.h>
70*4882a593Smuzhiyun 
71*4882a593Smuzhiyun #ifdef MITSHM
72*4882a593Smuzhiyun #include "shmint.h"
73*4882a593Smuzhiyun #endif
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun #include "darwin.h"
76*4882a593Smuzhiyun #include "darwinEvents.h"
77*4882a593Smuzhiyun #include "quartzKeyboard.h"
78*4882a593Smuzhiyun #include "quartz.h"
79*4882a593Smuzhiyun 
80*4882a593Smuzhiyun #include "X11Application.h"
81*4882a593Smuzhiyun 
82*4882a593Smuzhiyun aslclient aslc;
83*4882a593Smuzhiyun 
84*4882a593Smuzhiyun void
xq_asl_log(int level,const char * subsystem,const char * file,const char * function,int line,const char * fmt,...)85*4882a593Smuzhiyun xq_asl_log(int level, const char *subsystem, const char *file,
86*4882a593Smuzhiyun            const char *function, int line, const char *fmt,
87*4882a593Smuzhiyun            ...)
88*4882a593Smuzhiyun {
89*4882a593Smuzhiyun     va_list args;
90*4882a593Smuzhiyun     aslmsg msg = asl_new(ASL_TYPE_MSG);
91*4882a593Smuzhiyun 
92*4882a593Smuzhiyun     if (msg) {
93*4882a593Smuzhiyun         char *_line;
94*4882a593Smuzhiyun 
95*4882a593Smuzhiyun         asl_set(msg, "File", file);
96*4882a593Smuzhiyun         asl_set(msg, "Function", function);
97*4882a593Smuzhiyun         asprintf(&_line, "%d", line);
98*4882a593Smuzhiyun         if (_line) {
99*4882a593Smuzhiyun             asl_set(msg, "Line", _line);
100*4882a593Smuzhiyun             free(_line);
101*4882a593Smuzhiyun         }
102*4882a593Smuzhiyun         if (subsystem)
103*4882a593Smuzhiyun             asl_set(msg, "Subsystem", subsystem);
104*4882a593Smuzhiyun     }
105*4882a593Smuzhiyun 
106*4882a593Smuzhiyun     va_start(args, fmt);
107*4882a593Smuzhiyun     asl_vlog(aslc, msg, level, fmt, args);
108*4882a593Smuzhiyun     va_end(args);
109*4882a593Smuzhiyun 
110*4882a593Smuzhiyun     if (msg)
111*4882a593Smuzhiyun         asl_free(msg);
112*4882a593Smuzhiyun }
113*4882a593Smuzhiyun 
114*4882a593Smuzhiyun /*
115*4882a593Smuzhiyun  * X server shared global variables
116*4882a593Smuzhiyun  */
117*4882a593Smuzhiyun int darwinScreensFound = 0;
118*4882a593Smuzhiyun DevPrivateKeyRec darwinScreenKeyRec;
119*4882a593Smuzhiyun io_connect_t darwinParamConnect = 0;
120*4882a593Smuzhiyun int darwinEventReadFD = -1;
121*4882a593Smuzhiyun int darwinEventWriteFD = -1;
122*4882a593Smuzhiyun // int                     darwinMouseAccelChange = 1;
123*4882a593Smuzhiyun int darwinFakeButtons = 0;
124*4882a593Smuzhiyun 
125*4882a593Smuzhiyun // location of X11's (0,0) point in global screen coordinates
126*4882a593Smuzhiyun int darwinMainScreenX = 0;
127*4882a593Smuzhiyun int darwinMainScreenY = 0;
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun // parameters read from the command line or user preferences
130*4882a593Smuzhiyun int darwinDesiredDepth = -1;
131*4882a593Smuzhiyun int darwinSyncKeymap = FALSE;
132*4882a593Smuzhiyun 
133*4882a593Smuzhiyun // modifier masks for faking mouse buttons - ANY of these bits trigger it  (not all)
134*4882a593Smuzhiyun #ifdef NX_DEVICELCMDKEYMASK
135*4882a593Smuzhiyun int darwinFakeMouse2Mask = NX_DEVICELALTKEYMASK | NX_DEVICERALTKEYMASK;
136*4882a593Smuzhiyun int darwinFakeMouse3Mask = NX_DEVICELCMDKEYMASK | NX_DEVICERCMDKEYMASK;
137*4882a593Smuzhiyun #else
138*4882a593Smuzhiyun int darwinFakeMouse2Mask = NX_ALTERNATEMASK;
139*4882a593Smuzhiyun int darwinFakeMouse3Mask = NX_COMMANDMASK;
140*4882a593Smuzhiyun #endif
141*4882a593Smuzhiyun 
142*4882a593Smuzhiyun // Modifier mask for overriding event delivery to appkit (might be useful to set this to rcommand for input menu
143*4882a593Smuzhiyun unsigned int darwinAppKitModMask = 0;            // Any of these bits
144*4882a593Smuzhiyun 
145*4882a593Smuzhiyun // Modifier mask for items in the Window menu (0 and -1 cause shortcuts to be disabled)
146*4882a593Smuzhiyun unsigned int windowItemModMask = NX_COMMANDMASK;
147*4882a593Smuzhiyun 
148*4882a593Smuzhiyun // devices
149*4882a593Smuzhiyun DeviceIntPtr darwinKeyboard = NULL;
150*4882a593Smuzhiyun DeviceIntPtr darwinPointer = NULL;
151*4882a593Smuzhiyun DeviceIntPtr darwinTabletStylus = NULL;
152*4882a593Smuzhiyun DeviceIntPtr darwinTabletCursor = NULL;
153*4882a593Smuzhiyun DeviceIntPtr darwinTabletEraser = NULL;
154*4882a593Smuzhiyun 
155*4882a593Smuzhiyun // Common pixmap formats
156*4882a593Smuzhiyun static PixmapFormatRec formats[] = {
157*4882a593Smuzhiyun     { 1,  1,  BITMAP_SCANLINE_PAD    },
158*4882a593Smuzhiyun     { 4,  8,  BITMAP_SCANLINE_PAD    },
159*4882a593Smuzhiyun     { 8,  8,  BITMAP_SCANLINE_PAD    },
160*4882a593Smuzhiyun     { 15, 16, BITMAP_SCANLINE_PAD    },
161*4882a593Smuzhiyun     { 16, 16, BITMAP_SCANLINE_PAD    },
162*4882a593Smuzhiyun     { 24, 32, BITMAP_SCANLINE_PAD    },
163*4882a593Smuzhiyun     { 32, 32, BITMAP_SCANLINE_PAD    }
164*4882a593Smuzhiyun };
165*4882a593Smuzhiyun 
166*4882a593Smuzhiyun void
DarwinPrintBanner(void)167*4882a593Smuzhiyun DarwinPrintBanner(void)
168*4882a593Smuzhiyun {
169*4882a593Smuzhiyun     ErrorF("Xquartz starting:\n");
170*4882a593Smuzhiyun     ErrorF("X.Org X Server %s\n", XSERVER_VERSION);
171*4882a593Smuzhiyun     ErrorF("Build Date: %s\n", BUILD_DATE);
172*4882a593Smuzhiyun }
173*4882a593Smuzhiyun 
174*4882a593Smuzhiyun /*
175*4882a593Smuzhiyun  * DarwinSaveScreen
176*4882a593Smuzhiyun  *  X screensaver support. Not implemented.
177*4882a593Smuzhiyun  */
178*4882a593Smuzhiyun static Bool
DarwinSaveScreen(ScreenPtr pScreen,int on)179*4882a593Smuzhiyun DarwinSaveScreen(ScreenPtr pScreen, int on)
180*4882a593Smuzhiyun {
181*4882a593Smuzhiyun     // FIXME
182*4882a593Smuzhiyun     if (on == SCREEN_SAVER_FORCER) {}
183*4882a593Smuzhiyun     else if (on == SCREEN_SAVER_ON) {}
184*4882a593Smuzhiyun     else {}
185*4882a593Smuzhiyun     return TRUE;
186*4882a593Smuzhiyun }
187*4882a593Smuzhiyun 
188*4882a593Smuzhiyun /*
189*4882a593Smuzhiyun  * DarwinScreenInit
190*4882a593Smuzhiyun  *  This is a callback from dix during AddScreen() from InitOutput().
191*4882a593Smuzhiyun  *  Initialize the screen and communicate information about it back to dix.
192*4882a593Smuzhiyun  */
193*4882a593Smuzhiyun static Bool
DarwinScreenInit(ScreenPtr pScreen,int argc,char ** argv)194*4882a593Smuzhiyun DarwinScreenInit(ScreenPtr pScreen, int argc, char **argv)
195*4882a593Smuzhiyun {
196*4882a593Smuzhiyun     int dpi;
197*4882a593Smuzhiyun     static int foundIndex = 0;
198*4882a593Smuzhiyun     Bool ret;
199*4882a593Smuzhiyun     DarwinFramebufferPtr dfb;
200*4882a593Smuzhiyun 
201*4882a593Smuzhiyun     if (!dixRegisterPrivateKey(&darwinScreenKeyRec, PRIVATE_SCREEN, 0))
202*4882a593Smuzhiyun         return FALSE;
203*4882a593Smuzhiyun 
204*4882a593Smuzhiyun     // reset index of found screens for each server generation
205*4882a593Smuzhiyun     if (pScreen->myNum == 0) {
206*4882a593Smuzhiyun         foundIndex = 0;
207*4882a593Smuzhiyun 
208*4882a593Smuzhiyun         // reset the visual list
209*4882a593Smuzhiyun         miClearVisualTypes();
210*4882a593Smuzhiyun     }
211*4882a593Smuzhiyun 
212*4882a593Smuzhiyun     // allocate space for private per screen storage
213*4882a593Smuzhiyun     dfb = malloc(sizeof(DarwinFramebufferRec));
214*4882a593Smuzhiyun 
215*4882a593Smuzhiyun     // SCREEN_PRIV(pScreen) = dfb;
216*4882a593Smuzhiyun     dixSetPrivate(&pScreen->devPrivates, darwinScreenKey, dfb);
217*4882a593Smuzhiyun 
218*4882a593Smuzhiyun     // setup hardware/mode specific details
219*4882a593Smuzhiyun     ret = QuartzAddScreen(foundIndex, pScreen);
220*4882a593Smuzhiyun     foundIndex++;
221*4882a593Smuzhiyun     if (!ret)
222*4882a593Smuzhiyun         return FALSE;
223*4882a593Smuzhiyun 
224*4882a593Smuzhiyun     // setup a single visual appropriate for our pixel type
225*4882a593Smuzhiyun     if (!miSetVisualTypesAndMasks(dfb->depth, dfb->visuals, dfb->bitsPerRGB,
226*4882a593Smuzhiyun                                   dfb->preferredCVC, dfb->redMask,
227*4882a593Smuzhiyun                                   dfb->greenMask, dfb->blueMask)) {
228*4882a593Smuzhiyun         return FALSE;
229*4882a593Smuzhiyun     }
230*4882a593Smuzhiyun 
231*4882a593Smuzhiyun     // TODO: Make PseudoColor visuals not suck in TrueColor mode
232*4882a593Smuzhiyun     // if(dfb->depth > 8)
233*4882a593Smuzhiyun     //    miSetVisualTypesAndMasks(8, PseudoColorMask, 8, PseudoColor, 0, 0, 0);
234*4882a593Smuzhiyun     //
235*4882a593Smuzhiyun     // TODO: Re-add support for 15bit
236*4882a593Smuzhiyun     // if (dfb->depth > 15)
237*4882a593Smuzhiyun     //    miSetVisualTypesAndMasks(15, TrueColorMask, 5, TrueColor,
238*4882a593Smuzhiyun     //                             RM_ARGB(0, 5, 5, 5), GM_ARGB(0, 5, 5,
239*4882a593Smuzhiyun     //                                                          5),
240*4882a593Smuzhiyun     //                             BM_ARGB(0, 5, 5, 5));
241*4882a593Smuzhiyun     if (dfb->depth > 24)
242*4882a593Smuzhiyun         miSetVisualTypesAndMasks(24, TrueColorMask, 8, TrueColor,
243*4882a593Smuzhiyun                                  RM_ARGB(0, 8, 8, 8), GM_ARGB(0, 8, 8,
244*4882a593Smuzhiyun                                                               8),
245*4882a593Smuzhiyun                                  BM_ARGB(0, 8, 8, 8));
246*4882a593Smuzhiyun 
247*4882a593Smuzhiyun     miSetPixmapDepths();
248*4882a593Smuzhiyun 
249*4882a593Smuzhiyun     // machine independent screen init
250*4882a593Smuzhiyun     // setup _Screen structure in pScreen
251*4882a593Smuzhiyun     if (monitorResolution)
252*4882a593Smuzhiyun         dpi = monitorResolution;
253*4882a593Smuzhiyun     else
254*4882a593Smuzhiyun         dpi = 96;
255*4882a593Smuzhiyun 
256*4882a593Smuzhiyun     // initialize fb
257*4882a593Smuzhiyun     if (!fbScreenInit(pScreen,
258*4882a593Smuzhiyun                       dfb->framebuffer,                  // pointer to screen bitmap
259*4882a593Smuzhiyun                       dfb->width, dfb->height,           // screen size in pixels
260*4882a593Smuzhiyun                       dpi, dpi,                          // dots per inch
261*4882a593Smuzhiyun                       dfb->pitch / (dfb->bitsPerPixel / 8), // pixel width of framebuffer
262*4882a593Smuzhiyun                       dfb->bitsPerPixel)) {              // bits per pixel for screen
263*4882a593Smuzhiyun         return FALSE;
264*4882a593Smuzhiyun     }
265*4882a593Smuzhiyun 
266*4882a593Smuzhiyun     if (!fbPictureInit(pScreen, 0, 0)) {
267*4882a593Smuzhiyun         return FALSE;
268*4882a593Smuzhiyun     }
269*4882a593Smuzhiyun 
270*4882a593Smuzhiyun #ifdef MITSHM
271*4882a593Smuzhiyun     ShmRegisterFbFuncs(pScreen);
272*4882a593Smuzhiyun #endif
273*4882a593Smuzhiyun 
274*4882a593Smuzhiyun     // this must be initialized (why doesn't X have a default?)
275*4882a593Smuzhiyun     pScreen->SaveScreen = DarwinSaveScreen;
276*4882a593Smuzhiyun 
277*4882a593Smuzhiyun     // finish mode dependent screen setup including cursor support
278*4882a593Smuzhiyun     if (!QuartzSetupScreen(pScreen->myNum, pScreen)) {
279*4882a593Smuzhiyun         return FALSE;
280*4882a593Smuzhiyun     }
281*4882a593Smuzhiyun 
282*4882a593Smuzhiyun     // create and install the default colormap and
283*4882a593Smuzhiyun     // set pScreen->blackPixel / pScreen->white
284*4882a593Smuzhiyun     if (!miCreateDefColormap(pScreen)) {
285*4882a593Smuzhiyun         return FALSE;
286*4882a593Smuzhiyun     }
287*4882a593Smuzhiyun 
288*4882a593Smuzhiyun     pScreen->x = dfb->x;
289*4882a593Smuzhiyun     pScreen->y = dfb->y;
290*4882a593Smuzhiyun 
291*4882a593Smuzhiyun     /*    ErrorF("Screen %d added: %dx%d @ (%d,%d)\n",
292*4882a593Smuzhiyun        index, dfb->width, dfb->height, dfb->x, dfb->y); */
293*4882a593Smuzhiyun 
294*4882a593Smuzhiyun     return TRUE;
295*4882a593Smuzhiyun }
296*4882a593Smuzhiyun 
297*4882a593Smuzhiyun /*
298*4882a593Smuzhiyun    =============================================================================
299*4882a593Smuzhiyun 
300*4882a593Smuzhiyun    mouse and keyboard callbacks
301*4882a593Smuzhiyun 
302*4882a593Smuzhiyun    =============================================================================
303*4882a593Smuzhiyun  */
304*4882a593Smuzhiyun 
305*4882a593Smuzhiyun static void
DarwinInputHandlerNotify(int fd __unused,int ready __unused,void * data __unused)306*4882a593Smuzhiyun DarwinInputHandlerNotify(int fd __unused, int ready __unused, void *data __unused)
307*4882a593Smuzhiyun {
308*4882a593Smuzhiyun }
309*4882a593Smuzhiyun 
310*4882a593Smuzhiyun /*
311*4882a593Smuzhiyun  * DarwinMouseProc: Handle the initialization, etc. of a mouse
312*4882a593Smuzhiyun  */
313*4882a593Smuzhiyun static int
DarwinMouseProc(DeviceIntPtr pPointer,int what)314*4882a593Smuzhiyun DarwinMouseProc(DeviceIntPtr pPointer, int what)
315*4882a593Smuzhiyun {
316*4882a593Smuzhiyun #define NBUTTONS 3
317*4882a593Smuzhiyun #define NAXES    6
318*4882a593Smuzhiyun     // 3 buttons: left, middle, right
319*4882a593Smuzhiyun     CARD8 map[NBUTTONS + 1] = { 0, 1, 2, 3};
320*4882a593Smuzhiyun     Atom btn_labels[NBUTTONS] = { 0 };
321*4882a593Smuzhiyun     Atom axes_labels[NAXES] = { 0 };
322*4882a593Smuzhiyun 
323*4882a593Smuzhiyun     switch (what) {
324*4882a593Smuzhiyun     case DEVICE_INIT:
325*4882a593Smuzhiyun         pPointer->public.on = FALSE;
326*4882a593Smuzhiyun 
327*4882a593Smuzhiyun         btn_labels[0] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_LEFT);
328*4882a593Smuzhiyun         btn_labels[1] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_MIDDLE);
329*4882a593Smuzhiyun         btn_labels[2] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_RIGHT);
330*4882a593Smuzhiyun 
331*4882a593Smuzhiyun         axes_labels[0] = XIGetKnownProperty(AXIS_LABEL_PROP_ABS_X);
332*4882a593Smuzhiyun         axes_labels[1] = XIGetKnownProperty(AXIS_LABEL_PROP_ABS_Y);
333*4882a593Smuzhiyun         axes_labels[2] = XIGetKnownProperty(AXIS_LABEL_PROP_REL_X);
334*4882a593Smuzhiyun         axes_labels[3] = XIGetKnownProperty(AXIS_LABEL_PROP_REL_Y);
335*4882a593Smuzhiyun         axes_labels[4] = XIGetKnownProperty(AXIS_LABEL_PROP_REL_WHEEL);
336*4882a593Smuzhiyun         axes_labels[5] = XIGetKnownProperty(AXIS_LABEL_PROP_REL_HWHEEL);
337*4882a593Smuzhiyun 
338*4882a593Smuzhiyun         // Set button map.
339*4882a593Smuzhiyun         InitPointerDeviceStruct((DevicePtr)pPointer, map, NBUTTONS,
340*4882a593Smuzhiyun                                 btn_labels,
341*4882a593Smuzhiyun                                 (PtrCtrlProcPtr)NoopDDA,
342*4882a593Smuzhiyun                                 GetMotionHistorySize(), NAXES,
343*4882a593Smuzhiyun                                 axes_labels);
344*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 0, axes_labels[0],
345*4882a593Smuzhiyun                                NO_AXIS_LIMITS, NO_AXIS_LIMITS,
346*4882a593Smuzhiyun                                0, 0, 0, Absolute);
347*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 1, axes_labels[1],
348*4882a593Smuzhiyun                                NO_AXIS_LIMITS, NO_AXIS_LIMITS,
349*4882a593Smuzhiyun                                0, 0, 0, Absolute);
350*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 2, axes_labels[2],
351*4882a593Smuzhiyun                                NO_AXIS_LIMITS, NO_AXIS_LIMITS,
352*4882a593Smuzhiyun                                1, 0, 1, Relative);
353*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 3, axes_labels[3],
354*4882a593Smuzhiyun                                NO_AXIS_LIMITS, NO_AXIS_LIMITS,
355*4882a593Smuzhiyun                                1, 0, 1, Relative);
356*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 4, axes_labels[4],
357*4882a593Smuzhiyun                                NO_AXIS_LIMITS, NO_AXIS_LIMITS,
358*4882a593Smuzhiyun                                1, 0, 1, Relative);
359*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 5, axes_labels[5],
360*4882a593Smuzhiyun                                NO_AXIS_LIMITS, NO_AXIS_LIMITS,
361*4882a593Smuzhiyun                                1, 0, 1, Relative);
362*4882a593Smuzhiyun 
363*4882a593Smuzhiyun         SetScrollValuator(pPointer, 4, SCROLL_TYPE_VERTICAL, -1.0, SCROLL_FLAG_PREFERRED);
364*4882a593Smuzhiyun         SetScrollValuator(pPointer, 5, SCROLL_TYPE_HORIZONTAL, -1.0, SCROLL_FLAG_NONE);
365*4882a593Smuzhiyun         break;
366*4882a593Smuzhiyun 
367*4882a593Smuzhiyun     case DEVICE_ON:
368*4882a593Smuzhiyun         pPointer->public.on = TRUE;
369*4882a593Smuzhiyun         SetNotifyFd(darwinEventReadFD, DarwinInputHandlerNotify, X_NOTIFY_READ, NULL);
370*4882a593Smuzhiyun         return Success;
371*4882a593Smuzhiyun 
372*4882a593Smuzhiyun     case DEVICE_CLOSE:
373*4882a593Smuzhiyun     case DEVICE_OFF:
374*4882a593Smuzhiyun         pPointer->public.on = FALSE;
375*4882a593Smuzhiyun         RemoveNotifyFd(darwinEventReadFD);
376*4882a593Smuzhiyun         return Success;
377*4882a593Smuzhiyun     }
378*4882a593Smuzhiyun 
379*4882a593Smuzhiyun     return Success;
380*4882a593Smuzhiyun #undef NBUTTONS
381*4882a593Smuzhiyun #undef NAXES
382*4882a593Smuzhiyun }
383*4882a593Smuzhiyun 
384*4882a593Smuzhiyun static int
DarwinTabletProc(DeviceIntPtr pPointer,int what)385*4882a593Smuzhiyun DarwinTabletProc(DeviceIntPtr pPointer, int what)
386*4882a593Smuzhiyun {
387*4882a593Smuzhiyun #define NBUTTONS 3
388*4882a593Smuzhiyun #define NAXES    5
389*4882a593Smuzhiyun     CARD8 map[NBUTTONS + 1] = { 0, 1, 2, 3 };
390*4882a593Smuzhiyun     Atom btn_labels[NBUTTONS] = { 0 };
391*4882a593Smuzhiyun     Atom axes_labels[NAXES] = { 0 };
392*4882a593Smuzhiyun 
393*4882a593Smuzhiyun     switch (what) {
394*4882a593Smuzhiyun     case DEVICE_INIT:
395*4882a593Smuzhiyun         pPointer->public.on = FALSE;
396*4882a593Smuzhiyun 
397*4882a593Smuzhiyun         btn_labels[0] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_LEFT);
398*4882a593Smuzhiyun         btn_labels[1] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_MIDDLE);
399*4882a593Smuzhiyun         btn_labels[2] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_RIGHT);
400*4882a593Smuzhiyun 
401*4882a593Smuzhiyun         axes_labels[0] = XIGetKnownProperty(AXIS_LABEL_PROP_ABS_X);
402*4882a593Smuzhiyun         axes_labels[1] = XIGetKnownProperty(AXIS_LABEL_PROP_ABS_Y);
403*4882a593Smuzhiyun         axes_labels[2] = XIGetKnownProperty(AXIS_LABEL_PROP_ABS_PRESSURE);
404*4882a593Smuzhiyun         axes_labels[3] = XIGetKnownProperty(AXIS_LABEL_PROP_ABS_TILT_X);
405*4882a593Smuzhiyun         axes_labels[4] = XIGetKnownProperty(AXIS_LABEL_PROP_ABS_TILT_Y);
406*4882a593Smuzhiyun 
407*4882a593Smuzhiyun         // Set button map.
408*4882a593Smuzhiyun         InitPointerDeviceStruct((DevicePtr)pPointer, map, NBUTTONS,
409*4882a593Smuzhiyun                                 btn_labels,
410*4882a593Smuzhiyun                                 (PtrCtrlProcPtr)NoopDDA,
411*4882a593Smuzhiyun                                 GetMotionHistorySize(), NAXES,
412*4882a593Smuzhiyun                                 axes_labels);
413*4882a593Smuzhiyun         InitProximityClassDeviceStruct(pPointer);
414*4882a593Smuzhiyun 
415*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 0, axes_labels[0],
416*4882a593Smuzhiyun                                0, XQUARTZ_VALUATOR_LIMIT,
417*4882a593Smuzhiyun                                1, 0, 1, Absolute);
418*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 1, axes_labels[1],
419*4882a593Smuzhiyun                                0, XQUARTZ_VALUATOR_LIMIT,
420*4882a593Smuzhiyun                                1, 0, 1, Absolute);
421*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 2, axes_labels[2],
422*4882a593Smuzhiyun                                0, XQUARTZ_VALUATOR_LIMIT,
423*4882a593Smuzhiyun                                1, 0, 1, Absolute);
424*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 3, axes_labels[3],
425*4882a593Smuzhiyun                                -XQUARTZ_VALUATOR_LIMIT,
426*4882a593Smuzhiyun                                XQUARTZ_VALUATOR_LIMIT,
427*4882a593Smuzhiyun                                1, 0, 1, Absolute);
428*4882a593Smuzhiyun         InitValuatorAxisStruct(pPointer, 4, axes_labels[4],
429*4882a593Smuzhiyun                                -XQUARTZ_VALUATOR_LIMIT,
430*4882a593Smuzhiyun                                XQUARTZ_VALUATOR_LIMIT,
431*4882a593Smuzhiyun                                1, 0, 1, Absolute);
432*4882a593Smuzhiyun 
433*4882a593Smuzhiyun         //          pPointer->use = IsXExtensionDevice;
434*4882a593Smuzhiyun         break;
435*4882a593Smuzhiyun 
436*4882a593Smuzhiyun     case DEVICE_ON:
437*4882a593Smuzhiyun         pPointer->public.on = TRUE;
438*4882a593Smuzhiyun         SetNotifyFd(darwinEventReadFD, DarwinInputHandlerNotify, X_NOTIFY_READ, NULL);
439*4882a593Smuzhiyun         return Success;
440*4882a593Smuzhiyun 
441*4882a593Smuzhiyun     case DEVICE_CLOSE:
442*4882a593Smuzhiyun     case DEVICE_OFF:
443*4882a593Smuzhiyun         pPointer->public.on = FALSE;
444*4882a593Smuzhiyun         RemoveNotifyFd(darwinEventReadFD);
445*4882a593Smuzhiyun         return Success;
446*4882a593Smuzhiyun     }
447*4882a593Smuzhiyun     return Success;
448*4882a593Smuzhiyun #undef NBUTTONS
449*4882a593Smuzhiyun #undef NAXES
450*4882a593Smuzhiyun }
451*4882a593Smuzhiyun 
452*4882a593Smuzhiyun /*
453*4882a593Smuzhiyun  * DarwinKeybdProc
454*4882a593Smuzhiyun  *  Callback from X
455*4882a593Smuzhiyun  */
456*4882a593Smuzhiyun static int
DarwinKeybdProc(DeviceIntPtr pDev,int onoff)457*4882a593Smuzhiyun DarwinKeybdProc(DeviceIntPtr pDev, int onoff)
458*4882a593Smuzhiyun {
459*4882a593Smuzhiyun     switch (onoff) {
460*4882a593Smuzhiyun     case DEVICE_INIT:
461*4882a593Smuzhiyun         DarwinKeyboardInit(pDev);
462*4882a593Smuzhiyun         break;
463*4882a593Smuzhiyun 
464*4882a593Smuzhiyun     case DEVICE_ON:
465*4882a593Smuzhiyun         pDev->public.on = TRUE;
466*4882a593Smuzhiyun         SetNotifyFd(darwinEventReadFD, DarwinInputHandlerNotify, X_NOTIFY_READ, NULL);
467*4882a593Smuzhiyun         break;
468*4882a593Smuzhiyun 
469*4882a593Smuzhiyun     case DEVICE_OFF:
470*4882a593Smuzhiyun         pDev->public.on = FALSE;
471*4882a593Smuzhiyun         RemoveNotifyFd(darwinEventReadFD);
472*4882a593Smuzhiyun         break;
473*4882a593Smuzhiyun 
474*4882a593Smuzhiyun     case DEVICE_CLOSE:
475*4882a593Smuzhiyun         break;
476*4882a593Smuzhiyun     }
477*4882a593Smuzhiyun 
478*4882a593Smuzhiyun     return Success;
479*4882a593Smuzhiyun }
480*4882a593Smuzhiyun 
481*4882a593Smuzhiyun /*
482*4882a593Smuzhiyun    ===========================================================================
483*4882a593Smuzhiyun 
484*4882a593Smuzhiyun    Utility routines
485*4882a593Smuzhiyun 
486*4882a593Smuzhiyun    ===========================================================================
487*4882a593Smuzhiyun  */
488*4882a593Smuzhiyun 
489*4882a593Smuzhiyun /*
490*4882a593Smuzhiyun  * DarwinParseModifierList
491*4882a593Smuzhiyun  *  Parse a list of modifier names and return a corresponding modifier mask
492*4882a593Smuzhiyun  */
493*4882a593Smuzhiyun int
DarwinParseModifierList(const char * constmodifiers,int separatelr)494*4882a593Smuzhiyun DarwinParseModifierList(const char *constmodifiers, int separatelr)
495*4882a593Smuzhiyun {
496*4882a593Smuzhiyun     int result = 0;
497*4882a593Smuzhiyun 
498*4882a593Smuzhiyun     if (constmodifiers) {
499*4882a593Smuzhiyun         char *modifiers = strdup(constmodifiers);
500*4882a593Smuzhiyun         char *modifier;
501*4882a593Smuzhiyun         int nxkey;
502*4882a593Smuzhiyun         char *p = modifiers;
503*4882a593Smuzhiyun 
504*4882a593Smuzhiyun         while (p) {
505*4882a593Smuzhiyun             modifier = strsep(&p, " ,+&|/"); // allow lots of separators
506*4882a593Smuzhiyun             nxkey = DarwinModifierStringToNXMask(modifier, separatelr);
507*4882a593Smuzhiyun             if (nxkey)
508*4882a593Smuzhiyun                 result |= nxkey;
509*4882a593Smuzhiyun             else
510*4882a593Smuzhiyun                 ErrorF("fakebuttons: Unknown modifier \"%s\"\n", modifier);
511*4882a593Smuzhiyun         }
512*4882a593Smuzhiyun         free(modifiers);
513*4882a593Smuzhiyun     }
514*4882a593Smuzhiyun     return result;
515*4882a593Smuzhiyun }
516*4882a593Smuzhiyun 
517*4882a593Smuzhiyun /*
518*4882a593Smuzhiyun    ===========================================================================
519*4882a593Smuzhiyun 
520*4882a593Smuzhiyun    Functions needed to link against device independent X
521*4882a593Smuzhiyun 
522*4882a593Smuzhiyun    ===========================================================================
523*4882a593Smuzhiyun  */
524*4882a593Smuzhiyun 
525*4882a593Smuzhiyun /*
526*4882a593Smuzhiyun  * InitInput
527*4882a593Smuzhiyun  *  Register the keyboard and mouse devices
528*4882a593Smuzhiyun  */
529*4882a593Smuzhiyun void
InitInput(int argc,char ** argv)530*4882a593Smuzhiyun InitInput(int argc, char **argv)
531*4882a593Smuzhiyun {
532*4882a593Smuzhiyun     XkbRMLVOSet rmlvo = {
533*4882a593Smuzhiyun         .rules   = "base", .model         = "empty", .layout = "empty",
534*4882a593Smuzhiyun         .variant = NULL,   .options       = NULL
535*4882a593Smuzhiyun     };
536*4882a593Smuzhiyun 
537*4882a593Smuzhiyun     /* We need to really have rules... or something... */
538*4882a593Smuzhiyun     XkbSetRulesDflts(&rmlvo);
539*4882a593Smuzhiyun 
540*4882a593Smuzhiyun     assert(Success == AllocDevicePair(serverClient, "xquartz virtual",
541*4882a593Smuzhiyun                                       &darwinPointer, &darwinKeyboard,
542*4882a593Smuzhiyun                                       DarwinMouseProc, DarwinKeybdProc, FALSE));
543*4882a593Smuzhiyun 
544*4882a593Smuzhiyun     /* here's the snippet from the current gdk sources:
545*4882a593Smuzhiyun        if (!strcmp (tmp_name, "pointer"))
546*4882a593Smuzhiyun        gdkdev->info.source = GDK_SOURCE_MOUSE;
547*4882a593Smuzhiyun        else if (!strcmp (tmp_name, "wacom") ||
548*4882a593Smuzhiyun        !strcmp (tmp_name, "pen"))
549*4882a593Smuzhiyun        gdkdev->info.source = GDK_SOURCE_PEN;
550*4882a593Smuzhiyun        else if (!strcmp (tmp_name, "eraser"))
551*4882a593Smuzhiyun        gdkdev->info.source = GDK_SOURCE_ERASER;
552*4882a593Smuzhiyun        else if (!strcmp (tmp_name, "cursor"))
553*4882a593Smuzhiyun        gdkdev->info.source = GDK_SOURCE_CURSOR;
554*4882a593Smuzhiyun        else
555*4882a593Smuzhiyun        gdkdev->info.source = GDK_SOURCE_PEN;
556*4882a593Smuzhiyun      */
557*4882a593Smuzhiyun 
558*4882a593Smuzhiyun     darwinTabletStylus = AddInputDevice(serverClient, DarwinTabletProc, TRUE);
559*4882a593Smuzhiyun     assert(darwinTabletStylus);
560*4882a593Smuzhiyun     darwinTabletStylus->name = strdup("pen");
561*4882a593Smuzhiyun 
562*4882a593Smuzhiyun     darwinTabletCursor = AddInputDevice(serverClient, DarwinTabletProc, TRUE);
563*4882a593Smuzhiyun     assert(darwinTabletCursor);
564*4882a593Smuzhiyun     darwinTabletCursor->name = strdup("cursor");
565*4882a593Smuzhiyun 
566*4882a593Smuzhiyun     darwinTabletEraser = AddInputDevice(serverClient, DarwinTabletProc, TRUE);
567*4882a593Smuzhiyun     assert(darwinTabletEraser);
568*4882a593Smuzhiyun     darwinTabletEraser->name = strdup("eraser");
569*4882a593Smuzhiyun 
570*4882a593Smuzhiyun     DarwinEQInit();
571*4882a593Smuzhiyun 
572*4882a593Smuzhiyun     QuartzInitInput(argc, argv);
573*4882a593Smuzhiyun }
574*4882a593Smuzhiyun 
575*4882a593Smuzhiyun void
CloseInput(void)576*4882a593Smuzhiyun CloseInput(void)
577*4882a593Smuzhiyun {
578*4882a593Smuzhiyun     DarwinEQFini();
579*4882a593Smuzhiyun }
580*4882a593Smuzhiyun 
581*4882a593Smuzhiyun /*
582*4882a593Smuzhiyun  * DarwinAdjustScreenOrigins
583*4882a593Smuzhiyun  *  Shift all screens so the X11 (0, 0) coordinate is at the top
584*4882a593Smuzhiyun  *  left of the global screen coordinates.
585*4882a593Smuzhiyun  *
586*4882a593Smuzhiyun  *  Screens can be arranged so the top left isn't on any screen, so
587*4882a593Smuzhiyun  *  instead use the top left of the leftmost screen as (0,0). This
588*4882a593Smuzhiyun  *  may mean some screen space is in -y, but it's better that (0,0)
589*4882a593Smuzhiyun  *  be onscreen, or else default xterms disappear. It's better that
590*4882a593Smuzhiyun  *  -y be used than -x, because when popup menus are forced
591*4882a593Smuzhiyun  *  "onscreen" by dumb window managers like twm, they'll shift the
592*4882a593Smuzhiyun  *  menus down instead of left, which still looks funny but is an
593*4882a593Smuzhiyun  *  easier target to hit.
594*4882a593Smuzhiyun  */
595*4882a593Smuzhiyun void
DarwinAdjustScreenOrigins(ScreenInfo * pScreenInfo)596*4882a593Smuzhiyun DarwinAdjustScreenOrigins(ScreenInfo *pScreenInfo)
597*4882a593Smuzhiyun {
598*4882a593Smuzhiyun     int i, left, top;
599*4882a593Smuzhiyun 
600*4882a593Smuzhiyun     left = pScreenInfo->screens[0]->x;
601*4882a593Smuzhiyun     top = pScreenInfo->screens[0]->y;
602*4882a593Smuzhiyun 
603*4882a593Smuzhiyun     /* Find leftmost screen. If there's a tie, take the topmost of the two. */
604*4882a593Smuzhiyun     for (i = 1; i < pScreenInfo->numScreens; i++) {
605*4882a593Smuzhiyun         if (pScreenInfo->screens[i]->x < left ||
606*4882a593Smuzhiyun             (pScreenInfo->screens[i]->x == left &&
607*4882a593Smuzhiyun              pScreenInfo->screens[i]->y < top)) {
608*4882a593Smuzhiyun             left = pScreenInfo->screens[i]->x;
609*4882a593Smuzhiyun             top = pScreenInfo->screens[i]->y;
610*4882a593Smuzhiyun         }
611*4882a593Smuzhiyun     }
612*4882a593Smuzhiyun 
613*4882a593Smuzhiyun     darwinMainScreenX = left;
614*4882a593Smuzhiyun     darwinMainScreenY = top;
615*4882a593Smuzhiyun 
616*4882a593Smuzhiyun     DEBUG_LOG("top = %d, left=%d\n", top, left);
617*4882a593Smuzhiyun 
618*4882a593Smuzhiyun     /* Shift all screens so that there is a screen whose top left
619*4882a593Smuzhiyun      * is at X11 (0,0) and at global screen coordinate
620*4882a593Smuzhiyun      * (darwinMainScreenX, darwinMainScreenY).
621*4882a593Smuzhiyun      */
622*4882a593Smuzhiyun 
623*4882a593Smuzhiyun     if (darwinMainScreenX != 0 || darwinMainScreenY != 0) {
624*4882a593Smuzhiyun         for (i = 0; i < pScreenInfo->numScreens; i++) {
625*4882a593Smuzhiyun             pScreenInfo->screens[i]->x -= darwinMainScreenX;
626*4882a593Smuzhiyun             pScreenInfo->screens[i]->y -= darwinMainScreenY;
627*4882a593Smuzhiyun             DEBUG_LOG("Screen %d placed at X11 coordinate (%d,%d).\n",
628*4882a593Smuzhiyun                       i, pScreenInfo->screens[i]->x,
629*4882a593Smuzhiyun                       pScreenInfo->screens[i]->y);
630*4882a593Smuzhiyun         }
631*4882a593Smuzhiyun     }
632*4882a593Smuzhiyun 
633*4882a593Smuzhiyun     /* Update screenInfo.x/y */
634*4882a593Smuzhiyun     update_desktop_dimensions();
635*4882a593Smuzhiyun }
636*4882a593Smuzhiyun 
637*4882a593Smuzhiyun /*
638*4882a593Smuzhiyun  * InitOutput
639*4882a593Smuzhiyun  *  Initialize screenInfo for all actually accessible framebuffers.
640*4882a593Smuzhiyun  *
641*4882a593Smuzhiyun  *  The display mode dependent code gets called three times. The mode
642*4882a593Smuzhiyun  *  specific InitOutput routines are expected to discover the number
643*4882a593Smuzhiyun  *  of potentially useful screens and cache routes to them internally.
644*4882a593Smuzhiyun  *  Inside DarwinScreenInit are two other mode specific calls.
645*4882a593Smuzhiyun  *  A mode specific AddScreen routine is called for each screen to
646*4882a593Smuzhiyun  *  actually initialize the screen with the ScreenPtr structure.
647*4882a593Smuzhiyun  *  After other screen setup has been done, a mode specific
648*4882a593Smuzhiyun  *  SetupScreen function can be called to finalize screen setup.
649*4882a593Smuzhiyun  */
650*4882a593Smuzhiyun void
InitOutput(ScreenInfo * pScreenInfo,int argc,char ** argv)651*4882a593Smuzhiyun InitOutput(ScreenInfo *pScreenInfo, int argc, char **argv)
652*4882a593Smuzhiyun {
653*4882a593Smuzhiyun     int i;
654*4882a593Smuzhiyun 
655*4882a593Smuzhiyun     pScreenInfo->imageByteOrder = IMAGE_BYTE_ORDER;
656*4882a593Smuzhiyun     pScreenInfo->bitmapScanlineUnit = BITMAP_SCANLINE_UNIT;
657*4882a593Smuzhiyun     pScreenInfo->bitmapScanlinePad = BITMAP_SCANLINE_PAD;
658*4882a593Smuzhiyun     pScreenInfo->bitmapBitOrder = BITMAP_BIT_ORDER;
659*4882a593Smuzhiyun 
660*4882a593Smuzhiyun     // List how we want common pixmap formats to be padded
661*4882a593Smuzhiyun     pScreenInfo->numPixmapFormats = ARRAY_SIZE(formats);
662*4882a593Smuzhiyun     for (i = 0; i < ARRAY_SIZE(formats); i++)
663*4882a593Smuzhiyun         pScreenInfo->formats[i] = formats[i];
664*4882a593Smuzhiyun 
665*4882a593Smuzhiyun     // Discover screens and do mode specific initialization
666*4882a593Smuzhiyun     QuartzInitOutput(argc, argv);
667*4882a593Smuzhiyun 
668*4882a593Smuzhiyun     // Add screens
669*4882a593Smuzhiyun     for (i = 0; i < darwinScreensFound; i++) {
670*4882a593Smuzhiyun         AddScreen(DarwinScreenInit, argc, argv);
671*4882a593Smuzhiyun     }
672*4882a593Smuzhiyun 
673*4882a593Smuzhiyun     xorgGlxCreateVendor();
674*4882a593Smuzhiyun 
675*4882a593Smuzhiyun     DarwinAdjustScreenOrigins(pScreenInfo);
676*4882a593Smuzhiyun }
677*4882a593Smuzhiyun 
678*4882a593Smuzhiyun /*
679*4882a593Smuzhiyun  * OsVendorFatalError
680*4882a593Smuzhiyun  */
681*4882a593Smuzhiyun void
OsVendorFatalError(const char * f,va_list args)682*4882a593Smuzhiyun OsVendorFatalError(const char *f, va_list args)
683*4882a593Smuzhiyun {
684*4882a593Smuzhiyun }
685*4882a593Smuzhiyun 
686*4882a593Smuzhiyun /*
687*4882a593Smuzhiyun  * OsVendorInit
688*4882a593Smuzhiyun  *  Initialization of Darwin OS support.
689*4882a593Smuzhiyun  */
690*4882a593Smuzhiyun void
OsVendorInit(void)691*4882a593Smuzhiyun OsVendorInit(void)
692*4882a593Smuzhiyun {
693*4882a593Smuzhiyun     if (serverGeneration == 1) {
694*4882a593Smuzhiyun         char *lf;
695*4882a593Smuzhiyun         char *home = getenv("HOME");
696*4882a593Smuzhiyun         assert(home);
697*4882a593Smuzhiyun         assert(0 < asprintf(&lf, "%s/Library/Logs/X11", home));
698*4882a593Smuzhiyun 
699*4882a593Smuzhiyun         /* Ignore errors.  If EEXIST, we don't care.  If anything else,
700*4882a593Smuzhiyun          * LogInit will handle it for us.
701*4882a593Smuzhiyun          */
702*4882a593Smuzhiyun         (void)mkdir(lf, S_IRWXU | S_IRWXG | S_IRWXO);
703*4882a593Smuzhiyun         free(lf);
704*4882a593Smuzhiyun 
705*4882a593Smuzhiyun         assert(0 <
706*4882a593Smuzhiyun                asprintf(&lf, "%s/Library/Logs/X11/%s.log", home,
707*4882a593Smuzhiyun                         bundle_id_prefix));
708*4882a593Smuzhiyun         LogInit(lf, ".old");
709*4882a593Smuzhiyun         free(lf);
710*4882a593Smuzhiyun 
711*4882a593Smuzhiyun         DarwinPrintBanner();
712*4882a593Smuzhiyun     }
713*4882a593Smuzhiyun }
714*4882a593Smuzhiyun 
715*4882a593Smuzhiyun /*
716*4882a593Smuzhiyun  * ddxProcessArgument
717*4882a593Smuzhiyun  *  Process device-dependent command line args. Returns 0 if argument is
718*4882a593Smuzhiyun  *  not device dependent, otherwise Count of number of elements of argv
719*4882a593Smuzhiyun  *  that are part of a device dependent commandline option.
720*4882a593Smuzhiyun  */
721*4882a593Smuzhiyun int
ddxProcessArgument(int argc,char * argv[],int i)722*4882a593Smuzhiyun ddxProcessArgument(int argc, char *argv[], int i)
723*4882a593Smuzhiyun {
724*4882a593Smuzhiyun     //    if ( !strcmp( argv[i], "-fullscreen" ) ) {
725*4882a593Smuzhiyun     //        ErrorF( "Running full screen in parallel with Mac OS X Quartz window server.\n" );
726*4882a593Smuzhiyun     //        return 1;
727*4882a593Smuzhiyun     //    }
728*4882a593Smuzhiyun 
729*4882a593Smuzhiyun     //    if ( !strcmp( argv[i], "-rootless" ) ) {
730*4882a593Smuzhiyun     //        ErrorF( "Running rootless inside Mac OS X window server.\n" );
731*4882a593Smuzhiyun     //        return 1;
732*4882a593Smuzhiyun     //    }
733*4882a593Smuzhiyun 
734*4882a593Smuzhiyun     // This command line arg is passed when launched from the Aqua GUI.
735*4882a593Smuzhiyun     if (!strncmp(argv[i], "-psn_", 5)) {
736*4882a593Smuzhiyun         return 1;
737*4882a593Smuzhiyun     }
738*4882a593Smuzhiyun 
739*4882a593Smuzhiyun     if (!strcmp(argv[i], "-fakebuttons")) {
740*4882a593Smuzhiyun         darwinFakeButtons = TRUE;
741*4882a593Smuzhiyun         ErrorF("Faking a three button mouse\n");
742*4882a593Smuzhiyun         return 1;
743*4882a593Smuzhiyun     }
744*4882a593Smuzhiyun 
745*4882a593Smuzhiyun     if (!strcmp(argv[i], "-nofakebuttons")) {
746*4882a593Smuzhiyun         darwinFakeButtons = FALSE;
747*4882a593Smuzhiyun         ErrorF("Not faking a three button mouse\n");
748*4882a593Smuzhiyun         return 1;
749*4882a593Smuzhiyun     }
750*4882a593Smuzhiyun 
751*4882a593Smuzhiyun     if (!strcmp(argv[i], "-fakemouse2")) {
752*4882a593Smuzhiyun         if (i == argc - 1) {
753*4882a593Smuzhiyun             FatalError("-fakemouse2 must be followed by a modifier list\n");
754*4882a593Smuzhiyun         }
755*4882a593Smuzhiyun         if (!strcasecmp(argv[i + 1], "none") || !strcmp(argv[i + 1], ""))
756*4882a593Smuzhiyun             darwinFakeMouse2Mask = 0;
757*4882a593Smuzhiyun         else
758*4882a593Smuzhiyun             darwinFakeMouse2Mask = DarwinParseModifierList(argv[i + 1], 1);
759*4882a593Smuzhiyun         ErrorF("Modifier mask to fake mouse button 2 = 0x%x\n",
760*4882a593Smuzhiyun                darwinFakeMouse2Mask);
761*4882a593Smuzhiyun         return 2;
762*4882a593Smuzhiyun     }
763*4882a593Smuzhiyun 
764*4882a593Smuzhiyun     if (!strcmp(argv[i], "-fakemouse3")) {
765*4882a593Smuzhiyun         if (i == argc - 1) {
766*4882a593Smuzhiyun             FatalError("-fakemouse3 must be followed by a modifier list\n");
767*4882a593Smuzhiyun         }
768*4882a593Smuzhiyun         if (!strcasecmp(argv[i + 1], "none") || !strcmp(argv[i + 1], ""))
769*4882a593Smuzhiyun             darwinFakeMouse3Mask = 0;
770*4882a593Smuzhiyun         else
771*4882a593Smuzhiyun             darwinFakeMouse3Mask = DarwinParseModifierList(argv[i + 1], 1);
772*4882a593Smuzhiyun         ErrorF("Modifier mask to fake mouse button 3 = 0x%x\n",
773*4882a593Smuzhiyun                darwinFakeMouse3Mask);
774*4882a593Smuzhiyun         return 2;
775*4882a593Smuzhiyun     }
776*4882a593Smuzhiyun 
777*4882a593Smuzhiyun     if (!strcmp(argv[i], "+synckeymap")) {
778*4882a593Smuzhiyun         darwinSyncKeymap = TRUE;
779*4882a593Smuzhiyun         return 1;
780*4882a593Smuzhiyun     }
781*4882a593Smuzhiyun 
782*4882a593Smuzhiyun     if (!strcmp(argv[i], "-synckeymap")) {
783*4882a593Smuzhiyun         darwinSyncKeymap = FALSE;
784*4882a593Smuzhiyun         return 1;
785*4882a593Smuzhiyun     }
786*4882a593Smuzhiyun 
787*4882a593Smuzhiyun     if (!strcmp(argv[i], "-depth")) {
788*4882a593Smuzhiyun         if (i == argc - 1) {
789*4882a593Smuzhiyun             FatalError("-depth must be followed by a number\n");
790*4882a593Smuzhiyun         }
791*4882a593Smuzhiyun         darwinDesiredDepth = atoi(argv[i + 1]);
792*4882a593Smuzhiyun         if (darwinDesiredDepth != -1 &&
793*4882a593Smuzhiyun             darwinDesiredDepth != 8 &&
794*4882a593Smuzhiyun             darwinDesiredDepth != 15 &&
795*4882a593Smuzhiyun             darwinDesiredDepth != 24) {
796*4882a593Smuzhiyun             FatalError("Unsupported pixel depth. Use 8, 15, or 24 bits\n");
797*4882a593Smuzhiyun         }
798*4882a593Smuzhiyun 
799*4882a593Smuzhiyun         ErrorF("Attempting to use pixel depth of %i\n", darwinDesiredDepth);
800*4882a593Smuzhiyun         return 2;
801*4882a593Smuzhiyun     }
802*4882a593Smuzhiyun 
803*4882a593Smuzhiyun     if (!strcmp(argv[i], "-showconfig") || !strcmp(argv[i], "-version")) {
804*4882a593Smuzhiyun         DarwinPrintBanner();
805*4882a593Smuzhiyun         exit(0);
806*4882a593Smuzhiyun     }
807*4882a593Smuzhiyun 
808*4882a593Smuzhiyun     return 0;
809*4882a593Smuzhiyun }
810*4882a593Smuzhiyun 
811*4882a593Smuzhiyun /*
812*4882a593Smuzhiyun  * ddxUseMsg --
813*4882a593Smuzhiyun  *  Print out correct use of device dependent commandline options.
814*4882a593Smuzhiyun  *  Maybe the user now knows what really to do ...
815*4882a593Smuzhiyun  */
816*4882a593Smuzhiyun void
ddxUseMsg(void)817*4882a593Smuzhiyun ddxUseMsg(void)
818*4882a593Smuzhiyun {
819*4882a593Smuzhiyun     ErrorF("\n");
820*4882a593Smuzhiyun     ErrorF("\n");
821*4882a593Smuzhiyun     ErrorF("Device Dependent Usage:\n");
822*4882a593Smuzhiyun     ErrorF("\n");
823*4882a593Smuzhiyun     ErrorF("-depth <8,15,24> : use this bit depth.\n");
824*4882a593Smuzhiyun     ErrorF(
825*4882a593Smuzhiyun         "-fakebuttons : fake a three button mouse with Command and Option keys.\n");
826*4882a593Smuzhiyun     ErrorF("-nofakebuttons : don't fake a three button mouse.\n");
827*4882a593Smuzhiyun     ErrorF(
828*4882a593Smuzhiyun         "-fakemouse2 <modifiers> : fake middle mouse button with modifier keys.\n");
829*4882a593Smuzhiyun     ErrorF(
830*4882a593Smuzhiyun         "-fakemouse3 <modifiers> : fake right mouse button with modifier keys.\n");
831*4882a593Smuzhiyun     ErrorF(
832*4882a593Smuzhiyun         "  ex: -fakemouse2 \"option,shift\" = option-shift-click is middle button.\n");
833*4882a593Smuzhiyun     ErrorF("-version : show the server version.\n");
834*4882a593Smuzhiyun     ErrorF("\n");
835*4882a593Smuzhiyun }
836*4882a593Smuzhiyun 
837*4882a593Smuzhiyun /*
838*4882a593Smuzhiyun  * ddxGiveUp --
839*4882a593Smuzhiyun  *      Device dependent cleanup. Called by dix before normal server death.
840*4882a593Smuzhiyun  */
841*4882a593Smuzhiyun void
ddxGiveUp(enum ExitCode error)842*4882a593Smuzhiyun ddxGiveUp(enum ExitCode error)
843*4882a593Smuzhiyun {
844*4882a593Smuzhiyun     LogClose(error);
845*4882a593Smuzhiyun }
846*4882a593Smuzhiyun 
847*4882a593Smuzhiyun /*
848*4882a593Smuzhiyun  * AbortDDX --
849*4882a593Smuzhiyun  *      DDX - specific abort routine.  Called by AbortServer(). The attempt is
850*4882a593Smuzhiyun  *      made to restore all original setting of the displays. Also all devices
851*4882a593Smuzhiyun  *      are closed.
852*4882a593Smuzhiyun  */
853*4882a593Smuzhiyun _X_NORETURN
854*4882a593Smuzhiyun void
AbortDDX(enum ExitCode error)855*4882a593Smuzhiyun AbortDDX(enum ExitCode error)
856*4882a593Smuzhiyun {
857*4882a593Smuzhiyun     ErrorF("   AbortDDX\n");
858*4882a593Smuzhiyun     OsAbort();
859*4882a593Smuzhiyun }
860*4882a593Smuzhiyun 
861*4882a593Smuzhiyun #if INPUTTHREAD
862*4882a593Smuzhiyun /** This function is called in Xserver/os/inputthread.c when starting
863*4882a593Smuzhiyun     the input thread. */
864*4882a593Smuzhiyun void
ddxInputThreadInit(void)865*4882a593Smuzhiyun ddxInputThreadInit(void)
866*4882a593Smuzhiyun {
867*4882a593Smuzhiyun }
868*4882a593Smuzhiyun #endif
869