source: trunk/src/win32k/dev16/d16init.c@ 5878

Last change on this file since 5878 was 5480, checked in by bird, 25 years ago

Corrected typo in message.

File size: 9.4 KB
Line 
1/* $Id: d16init.c,v 1.11 2001-04-04 21:28:44 bird Exp $
2 *
3 * d16init - init routines for both drivers.
4 *
5 * IMPORTANT! Code and data defined here will be discarded after init is
6 * compleated. CodeEnd and DataEnd should not be set here.?
7 *
8 * Copyright (c) 1999-2000 knut st. osmundsen (knut.stange.osmundsen@mynd.no)
9 *
10 * Project Odin Software License can be found in LICENSE.TXT
11 *
12 */
13
14/*******************************************************************************
15* Defined Constants *
16*******************************************************************************/
17#define INCL_16
18#define INCL_DOSFILEMGR
19#define INCL_DOSDEVICES
20#define INCL_DOSMISC
21#define INCL_DOSERRORS
22#define INCL_NOPMAPI
23
24
25/*******************************************************************************
26* Header Files *
27*******************************************************************************/
28#include <os2.h>
29#include <devhdr.h>
30#include <devcmd.h>
31#include <strat2.h>
32#include <reqpkt.h>
33#include <dhcalls.h>
34
35#include <string.h>
36#include <memory.h>
37
38#include "devSegDf.h"
39#undef DATA16_INIT
40#define DATA16_INIT
41#undef CODE16_INIT
42#define CODE16_INIT
43#include "probkrnl.h"
44#include "dev1632.h"
45#include "dev16.h"
46#include "vprntf16.h"
47#include "log.h"
48#include "options.h"
49#include "errors.h"
50
51
52/**
53 * init function - device 0.
54 * Does nothing else than setting the device_help variable and
55 * fill the request packet.
56 * @returns Status word.
57 * @param pRpIn Pointer to input request packet. Actually the same memory as pRpOut but another struct.
58 * @param pRpOut Pointer to output request packet. Actually the same memory as pRpIn but another struct.
59 * @remark pRpIn and pRpOut points to the same memory.
60 */
61USHORT NEAR dev0Init(PRPINITIN pRpIn, PRPINITOUT pRpOut)
62{
63 APIRET rc;
64 Device_Help = pRpIn->DevHlpEP;
65
66 /*
67 * Does this work at Ring-3 (inittime)?
68 * If this work we could be saved from throuble!
69 */
70 rc = initGetDosTableData();
71 if (rc != NO_ERROR)
72 printf16("win32k - elf$: initGetDosTableData failed with rc=%d\n", rc);
73
74 pRpOut->BPBArray = NULL;
75 pRpOut->CodeEnd = (USHORT)&CODE16_INITSTART;
76 pRpOut->DataEnd = (USHORT)&DATA16_INITSTART;
77 pRpOut->Unit = 0;
78 pRpOut->rph.Status = STATUS_DONE;
79 return STATUS_DONE;
80}
81
82
83/**
84 * init function - device 1.
85 * We will send an IOCtl request to the elf$ (device 0) which will
86 * perform the Ring-0 initiation of the driver.
87 * @returns Status word.
88 * @param pRpIn Pointer to input request packet. Actually the same memory as pRpOut but another struct.
89 * @param pRpOut Pointer to output request packet. Actually the same memory as pRpIn but another struct.
90 * @remark pRpIn and pRpOut points to the same memory.
91 */
92USHORT NEAR dev1Init(PRPINITIN pRpIn, PRPINITOUT pRpOut)
93{
94 APIRET rc;
95 D16R0INITPARAM param;
96 D16R0INITDATA data = {0};
97 HFILE hDev0 = 0;
98 USHORT usAction = 0;
99 NPSZ npszErrMsg = NULL;
100 const char * npszErrMsg2 = NULL;
101
102 /*
103 * Probe kernel data.
104 */
105 rc = ProbeKernel(pRpIn);
106 if (rc == NO_ERROR)
107 {
108 /*
109 * Open and send a Ring-0 init packet to elf$.
110 * If this succeeds win32k$ init succeeds.
111 */
112 rc = DosOpen("\\dev\\elf$", &hDev0, &usAction, 0UL, FILE_NORMAL,
113 OPEN_ACTION_FAIL_IF_NEW | OPEN_ACTION_OPEN_IF_EXISTS,
114 OPEN_SHARE_DENYNONE | OPEN_ACCESS_READONLY,
115 0UL);
116 if (rc == NO_ERROR)
117 {
118 param.pRpInitIn = pRpIn;
119 rc = DosDevIOCtl(&data, &param, D16_IOCTL_RING0INIT, D16_IOCTL_CAT, hDev0);
120 if (rc == NO_ERROR)
121 {
122 if (data.usRcInit32 == NO_ERROR)
123 {
124 if (!options.fQuiet)
125 printf16("Win32k.sys successfully initiated!\n");
126 pRpOut->Status = pRpOut->rph.Status = STATUS_DONE;
127 }
128 else
129 {
130 /* set correct error message and rc */
131 rc = data.usRcInit32;
132 npszErrMsg = "Ring-0 initiation failed. rc=%x\n";
133 if (rc >= ERROR_D32_FIRST && rc <= ERROR_D32_LAST)
134 npszErrMsg2 =
135 GetErrorMsg(
136 data.usRcInit32
137 + ERROR_PROB_SYM_D32_FIRST
138 - ERROR_D32_FIRST
139 );
140 }
141 }
142 else
143 npszErrMsg = "Ring-0 init: DosDevIOCtl failed. rc=%d\n";
144 DosClose(hDev0);
145 }
146 else
147 npszErrMsg = "Ring-0 init: DosOpen failed. rc=%d\n";
148 }
149 else
150 npszErrMsg = ""; /* ProbeKrnl do its own complaining, but we need something here to indicate failure. */
151
152 /*
153 * Fill return data.
154 */
155 pRpOut->CodeEnd = (USHORT)&CODE16_INITSTART;
156 pRpOut->DataEnd = (USHORT)&DATA16_INITSTART;
157 pRpOut->BPBArray= NULL;
158 pRpOut->Unit = 0;
159
160 /*
161 * Any errors?, if so complain!
162 */
163 if (npszErrMsg)
164 {
165 printf16(npszErrMsg, rc);
166 if (npszErrMsg2)
167 printf16("%s\n", npszErrMsg2);
168 pRpOut->Status = pRpOut->rph.Status = STATUS_DONE | STERR | ERROR_I24_GEN_FAILURE;
169 }
170
171 /* Init is completed. */
172 fInitTime = FALSE;
173
174 /* successful return */
175 return pRpOut->rph.Status;
176}
177
178
179
180/**
181 * R0 16-bit initiation.
182 * This gets TKSSBase, thunks parameters and calls R0 32-bit initiation function.
183 * @returns Status word. We don't fail on R0Init32 but forwards the result
184 * using the usRcInit32.
185 * @param pRp Generic IO Control request packet.
186 */
187USHORT NEAR R0Init16(PRP_GENIOCTL pRp)
188{
189 USHORT usRc = STATUS_DONE;
190 APIRET rc;
191
192 /* First we're to get the DosTable2 stuff. */
193 rc = initGetDosTableData();
194 if (rc == NO_ERROR)
195 {
196 ULONG cPages;
197 char hLockParm[12] = {0};
198 ULONG ulLinParm;
199 char hLockData[12] = {0};
200 ULONG ulLinData;
201
202 /*
203 * Thunk the request packet and lock userdata.
204 */
205 if (!DevHelp_VirtToLin(SELECTOROF(pRp->ParmPacket), OFFSETOF(pRp->ParmPacket), &ulLinParm)
206 &&
207 !DevHelp_VirtToLin(SELECTOROF(pRp->DataPacket), OFFSETOF(pRp->DataPacket), &ulLinData)
208 )
209 {
210 if (!(rc = DevHelp_VMLock(VMDHL_LONG | VMDHL_WRITE,
211 ulLinParm, sizeof(D16R0INITPARAM),
212 (LIN)~0UL, SSToDS_16(&hLockParm[0]), &cPages))
213 &&
214 !DevHelp_VMLock(VMDHL_LONG | VMDHL_WRITE,
215 ulLinData, sizeof(D16R0INITDATA),
216 (LIN)~0UL, SSToDS_16(&hLockData[0]), &cPages)
217 )
218 {
219 /*
220 * -data and param is locked (do we need to lock the request packet too ?).-
221 * Create new 32-bit init packet - Parameter pointer is thunked.
222 */
223 RP32INIT rp32init;
224
225 _fmemcpy(&rp32init, ((PD16R0INITPARAM)pRp->ParmPacket)->pRpInitIn, sizeof(RPINITIN));
226 if (((PD16R0INITPARAM)pRp->ParmPacket)->pRpInitIn->InitArgs == NULL ||
227 !DevHelp_VirtToLin(SELECTOROF(rp32init.InitArgs), OFFSETOF(rp32init.InitArgs), (PLIN)&rp32init.InitArgs)
228 )
229 { /* call 32-bit init routine and set 32 bit rc. */
230 usRc = CallR0Init32(SSToDS_16(&rp32init));
231 ((PD16R0INITDATA)pRp->DataPacket)->usRcInit32 = usRc;
232
233 /* set status to done (success). (R0Init32 RC is return as usRcInit32.) */
234 usRc = STATUS_DONE;
235 }
236 else
237 usRc |= STERR | ERROR_I24_INVALID_PARAMETER;
238
239
240 /*
241 * finished - unlock data and parm;
242 */
243 DevHelp_VMUnLock((LIN)SSToDS_16(&hLockParm[0]));
244 DevHelp_VMUnLock((LIN)SSToDS_16(&hLockData[0]));
245 }
246 else
247 usRc |= STERR | ERROR_I24_INVALID_PARAMETER;
248 }
249 else
250 usRc |= STERR | ERROR_I24_INVALID_PARAMETER;
251 }
252 else
253 usRc |= STERR | ERROR_I24_GEN_FAILURE;
254
255 return usRc;
256}
257
258
259
260/**
261 * Gets the data we need from the DosTables.
262 * This data is TKSSBase16, R0FlatCS16 and R0FlatDS16.
263 * @returns Same as DevHelp_GetDosVar.
264 * @status completely implemented.
265 * @author knut st. osmundsen (knut.stange.osmundsen@mynd.no)
266 * @remark If you are not sure if TKSSBase16 is set or not, call this.
267 * After R0Init16 is called TKSSBase16 _is_ set.
268 * IMPORTANT! This function must _not_ be called after the initiation of the second device driver!!!
269 * (Since this is init code not present after init...)
270 */
271USHORT NEAR initGetDosTableData(void)
272{
273 APIRET rc;
274 PDOSTABLE pDT;
275 PDOSTABLE2 pDT2;
276
277 if (TKSSBase16 != 0)
278 return NO_ERROR;
279 /*
280 _asm {
281 int 3;
282 }
283 */
284
285 /* First we're to get the DosTable2 stuff. */
286 rc = DevHelp_GetDOSVar(9, 0, &pDT);
287 if (rc == NO_ERROR)
288 {
289 pDT2 = (PDOSTABLE2)((char FAR *)pDT + pDT->cul*4 + 1);
290 TKSSBase16 = (ULONG)pDT2->pTKSSBase;
291 R0FlatCS16 = (USHORT)pDT2->R0FlatCS;
292 R0FlatDS16 = (USHORT)pDT2->R0FlatDS;
293 }
294 return rc;
295}
296
Note: See TracBrowser for help on using the repository browser.