2020-09-30 16:53:55 +02:00

162 lines
3.4 KiB
C

/*++
Copyright (c) 1992 Microsoft Corporation
Module Name:
vxd.c
Abstract:
This module contains misc dpmi functions for risc.
Revision History:
Neil Sandlin (neilsa) Nov. 1, 95 - split off from "misc" source
--*/
#include "precomp.h"
#pragma hdrstop
#include "softpc.h"
#define W386_VCD_ID 0xe
VOID
GetVxDApiHandler(
USHORT VxdId
)
{
DECLARE_LocalVdmContext;
if (VxdId == W386_VCD_ID) {
setES(HIWORD(DosxVcdPmSvcCall));
setDI(LOWORD(DosxVcdPmSvcCall));
} else {
setES(0);
setDI(0);
}
}
LONG
VcdPmGetPortArray(
VOID
)
/*++
Routine Description:
Use the registry enteries in HKEY_LOCAL_MACHINE\\HARDWARE\\DEVICEMAP\\SERIALCOMM
to simulate the Virtual Comm Device API: VCD_PM_Get_Port_Array. See VCD.ASM
in the Win 3.1 DDK.
Arguments:
None
Return Value:
Port Array in LOWORD. Bit array of valid ports:
Bit Set -> Port valid
Bit clear -> Port invalid
Bit 0 -> COM1, Bit 1 -> COM2, Bit 2 -> COM3...
--*/
{
HKEY hSerialCommKey;
DWORD dwPortArray;
DWORD dwPortNum;
DWORD cbPortName;
DWORD cbPortValue;
CHAR szPortName[64];
CHAR szPortValue[64];
LONG iPort;
LONG iStatus;
dwPortArray = 0;
if (RegOpenKeyEx (HKEY_LOCAL_MACHINE,
"HARDWARE\\DEVICEMAP\\SERIALCOMM",
0, KEY_QUERY_VALUE | KEY_ENUMERATE_SUB_KEYS,
&hSerialCommKey) == ERROR_SUCCESS){
cbPortName = sizeof(szPortName);
cbPortValue = sizeof(szPortValue);
for (iPort = 0;
(iStatus = RegEnumValue(hSerialCommKey,
iPort, szPortName, &cbPortName,
NULL, NULL, szPortValue,
&cbPortValue)) != ERROR_NO_MORE_ITEMS;
iPort++)
{
if ((iStatus == ERROR_SUCCESS) && (cbPortValue > 3)) {
if (NT_SUCCESS(RtlCharToInteger(szPortValue+3,10,&dwPortNum))) {
dwPortArray |= (1 << (dwPortNum - 1));
}
}
cbPortName = sizeof(szPortName);
cbPortValue = sizeof(szPortValue);
}
// WOW only supports 9 ports. See WU32OPENCOM in WUCOMM.C.
dwPortArray &= 0x1FF;
RegCloseKey(hSerialCommKey);
}
return(dwPortArray);
}
// The following values taken from Win 3.1 DDK VCD.ASM:
#define VCD_PM_Get_Version 0
#define VCD_PM_Get_Port_Array 1
#define VCD_PM_Get_Port_Behavior 2
#define VCD_PM_Set_Port_Behavior 3
#define VCD_PM_Acquire_Port 4
#define VCD_PM_Free_Port 5
#define VCD_PM_Steal_Port 6
VOID
DpmiVcdPmSvcCall32(
VOID
)
/*++
Routine Description:
Dispatch VCD API requests to the correct API.
Arguments:
Client DX contains API function id.
Return Value:
Depends on API.
--*/
{
DECLARE_LocalVdmContext;
switch (getDX()) {
case VCD_PM_Get_Version:
setAX(0x30A);
break;
case VCD_PM_Get_Port_Array:
setAX((WORD)VcdPmGetPortArray());
break;
default :
ASSERT(0);
setCF(1);
}
}