windows-nt/Source/XPSP1/NT/drivers/parallel/parclass/par12843.c
2020-09-26 16:20:57 +08:00

189 lines
5.5 KiB
C
Raw Permalink Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

//+-------------------------------------------------------------------------
//
// 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;
}
}