mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
188 lines
5.5 KiB
188 lines
5.5 KiB
//+-------------------------------------------------------------------------
|
|
//
|
|
// Microsoft Windows
|
|
//
|
|
// Copyright (C) Microsoft Corporation, 1998 - 1999
|
|
//
|
|
// File: par12843.c
|
|
//
|
|
//--------------------------------------------------------------------------
|
|
|
|
//
|
|
// This file contains functions to select and deselect 1284.3 daisy chain devices
|
|
//
|
|
|
|
#include "pch.h"
|
|
|
|
BOOLEAN
|
|
ParSelectDevice(
|
|
IN PDEVICE_EXTENSION Extension,
|
|
IN BOOLEAN HavePort
|
|
)
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine acquires the ParPort and selects a 1284.3 device
|
|
|
|
Arguments:
|
|
|
|
Extension - Supplies the device extension.
|
|
|
|
HavePort - TRUE indicates that caller has already acquired port
|
|
so we should only do a SELECT_DEVICE
|
|
- FALSE indicates that caller has not already acquired port
|
|
so we should do a combination ACQUIRE_PORT/SELECT_DEVICE
|
|
|
|
Return Value:
|
|
|
|
TRUE - success - the device was selected (and port acquired if needed)
|
|
FALSE - failure
|
|
|
|
--*/
|
|
{
|
|
NTSTATUS status;
|
|
PDEVICE_OBJECT pPortDeviceObject;
|
|
PARALLEL_1284_COMMAND par1284Command;
|
|
LARGE_INTEGER timeOut;
|
|
|
|
// ParDumpP( ("par12843::ParSelectDevice - Enter\n") );
|
|
|
|
|
|
//
|
|
// Initialize command structure and extract parameters from the DeviceExtension
|
|
//
|
|
par1284Command.ID = (UCHAR)Extension->Ieee1284_3DeviceId;
|
|
par1284Command.Port = 0; // reserved - 0 for now
|
|
|
|
if( HavePort ) {
|
|
par1284Command.CommandFlags = PAR_HAVE_PORT_KEEP_PORT;
|
|
} else {
|
|
par1284Command.CommandFlags = 0;
|
|
}
|
|
|
|
if(Extension->EndOfChain) {
|
|
// this is NOT a daisy chain device - flag ParPort that
|
|
// the ID field of the command should be ignored
|
|
par1284Command.CommandFlags |= PAR_END_OF_CHAIN_DEVICE;
|
|
}
|
|
|
|
pPortDeviceObject = Extension->PortDeviceObject;
|
|
|
|
|
|
//
|
|
// Send the request
|
|
//
|
|
timeOut.QuadPart = -(10*1000*500); // 500ms ( 100ns units )
|
|
|
|
status = ParBuildSendInternalIoctl(IOCTL_INTERNAL_SELECT_DEVICE,
|
|
pPortDeviceObject,
|
|
&par1284Command, sizeof(PARALLEL_1284_COMMAND),
|
|
NULL, 0,
|
|
&timeOut);
|
|
|
|
if( NT_SUCCESS( status ) ) {
|
|
// SELECT succeeded
|
|
ParDump2(PARSELECTDESELECT, ("par12843::ParSelectDevice - SUCCESS\n") );
|
|
if( !HavePort ) {
|
|
// note in the device extension that we have the port
|
|
Extension->bAllocated = TRUE;
|
|
}
|
|
return TRUE;
|
|
} else {
|
|
// SELECT failed
|
|
ParDump2(PARSELECTDESELECT, ("par12843::ParSelectDevice - FAIL\n") );
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
BOOLEAN
|
|
ParDeselectDevice(
|
|
IN PDEVICE_EXTENSION Extension,
|
|
IN BOOLEAN KeepPort
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine deselects a 1284.3 device and releases the ParPort
|
|
|
|
Arguments:
|
|
|
|
Extension - Supplies the device extension.
|
|
|
|
KeepPort - TRUE indicates that we should keep the port acquired,
|
|
so we should only do a DESELECT_DEVICE
|
|
- FALSE indicates that we should not keep the port acquired,
|
|
so we should do a combination DESELECT_DEVICE/FREE_PORT
|
|
|
|
Return Value:
|
|
|
|
TRUE - The device was deselected (and the port released if requested)
|
|
FALSE - Failure
|
|
|
|
--*/
|
|
{
|
|
NTSTATUS status;
|
|
PDEVICE_OBJECT pPortDeviceObject;
|
|
PARALLEL_1284_COMMAND par1284Command;
|
|
|
|
// ParDumpP( ("par12843::ParDeselectDevice - Enter\n") );
|
|
|
|
//
|
|
// If we don't have the port, succeed and return
|
|
//
|
|
if( !Extension->bAllocated ) {
|
|
ParDump2(PARSELECTDESELECT, ("par12843::ParDeselectDevice: we do not have the port, returning TRUE/SUCCESS\n") );
|
|
return TRUE;
|
|
}
|
|
|
|
//
|
|
// Initialize command structure and extract parameters from the DeviceExtension
|
|
//
|
|
par1284Command.ID = (UCHAR)Extension->Ieee1284_3DeviceId;
|
|
par1284Command.Port = 0; // reserved - 0 for now
|
|
|
|
if( KeepPort ) {
|
|
par1284Command.CommandFlags = PAR_HAVE_PORT_KEEP_PORT;
|
|
} else {
|
|
par1284Command.CommandFlags = 0;
|
|
}
|
|
|
|
if(Extension->EndOfChain) {
|
|
// this is NOT a daisy chain device - flag ParPort that
|
|
// the ID field of the command should be ignored
|
|
par1284Command.CommandFlags |= PAR_END_OF_CHAIN_DEVICE;
|
|
}
|
|
|
|
pPortDeviceObject = Extension->PortDeviceObject;
|
|
|
|
|
|
//
|
|
// Send the request
|
|
//
|
|
status = ParBuildSendInternalIoctl(IOCTL_INTERNAL_DESELECT_DEVICE,
|
|
pPortDeviceObject,
|
|
&par1284Command, sizeof(PARALLEL_1284_COMMAND),
|
|
NULL, 0,
|
|
NULL);
|
|
|
|
if( NT_SUCCESS( status ) ) {
|
|
// DESELECT succeeded
|
|
if( !KeepPort ) {
|
|
// note in the device extension that we gave up the port
|
|
ParDump2(PARSELECTDESELECT, ("par12843::ParDeselectDevice - SUCCESS - giving up Port\n") );
|
|
Extension->bAllocated = FALSE;
|
|
} else {
|
|
ParDump2(PARSELECTDESELECT, ("par12843::ParDeselectDevice - SUCCESS - keeping Port\n") );
|
|
}
|
|
return TRUE;
|
|
} else {
|
|
// DESELECT failed
|
|
ParDump2(PARSELECTDESELECT, ("par12843::ParDeselectDevice - FAILED - status=%x\n", status) );
|
|
ASSERTMSG("DESELECT FAILED??? - this should never happen", FALSE );
|
|
return FALSE;
|
|
}
|
|
}
|
|
|