[CDFS][FLOPPY_NEW] Simplify unsupported NT6.2+ workarounds (#2956)

This commit is contained in:
Serge Gautherie 2020-07-18 15:31:48 +02:00 committed by GitHub
parent 5201472be7
commit 89971a3757
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 14 additions and 85 deletions

View file

@ -55,6 +55,14 @@ Abstract:
#pragma warning( pop ) #pragma warning( pop )
#endif #endif
#ifdef __REACTOS__
// Downgrade unsupported NT6.2+ features.
#undef MdlMappingNoExecute
#define MdlMappingNoExecute 0
#define NonPagedPoolNx NonPagedPool
#define NonPagedPoolNxCacheAligned NonPagedPoolCacheAligned
#endif
//**** x86 compiler bug **** //**** x86 compiler bug ****
#if defined(_M_IX86) #if defined(_M_IX86)
@ -372,7 +380,6 @@ CdHijackIrpAndFlushDevice (
// ); // );
// //
#ifndef __REACTOS__
#define CdMapUserBuffer(IC, UB) { \ #define CdMapUserBuffer(IC, UB) { \
*(UB) = (PVOID) ( ((IC)->Irp->MdlAddress == NULL) ? \ *(UB) = (PVOID) ( ((IC)->Irp->MdlAddress == NULL) ? \
(IC)->Irp->UserBuffer : \ (IC)->Irp->UserBuffer : \
@ -382,18 +389,6 @@ CdHijackIrpAndFlushDevice (
} \ } \
} }
#else
#define CdMapUserBuffer(IC, UB) { \
*(UB) = (PVOID) ( ((IC)->Irp->MdlAddress == NULL) ? \
(IC)->Irp->UserBuffer : \
(MmGetSystemAddressForMdlSafe( (IC)->Irp->MdlAddress, NormalPagePriority))); \
if (NULL == *(UB)) { \
CdRaiseStatus( (IC), STATUS_INSUFFICIENT_RESOURCES); \
} \
}
#endif
#define CdLockUserBuffer(IC,BL,OP) { \ #define CdLockUserBuffer(IC,BL,OP) { \
if ((IC)->Irp->MdlAddress == NULL) { \ if ((IC)->Irp->MdlAddress == NULL) { \
@ -1383,13 +1378,8 @@ CdProcessToc (
// //
#define CdPagedPool PagedPool #define CdPagedPool PagedPool
#ifndef __REACTOS__
#define CdNonPagedPool NonPagedPoolNx #define CdNonPagedPool NonPagedPoolNx
#define CdNonPagedPoolCacheAligned NonPagedPoolNxCacheAligned #define CdNonPagedPoolCacheAligned NonPagedPoolNxCacheAligned
#else
#define CdNonPagedPool NonPagedPool
#define CdNonPagedPoolCacheAligned NonPagedPoolCacheAligned
#endif
// //

View file

@ -46,6 +46,12 @@ Revision History:
#include <ntstrsafe.h> #include <ntstrsafe.h>
#include <intsafe.h> #include <intsafe.h>
#ifdef __REACTOS__
// Downgrade unsupported NT6.2+ features.
#define NonPagedPoolNx NonPagedPool
#define NonPagedPoolNxCacheAligned NonPagedPoolCacheAligned
#endif
#define MODE_DATA_SIZE 192 #define MODE_DATA_SIZE 192
#define SCSI_FLOPPY_TIMEOUT 20 #define SCSI_FLOPPY_TIMEOUT 20
#define SFLOPPY_SRB_LIST_SIZE 4 #define SFLOPPY_SRB_LIST_SIZE 4
@ -834,11 +840,7 @@ ScsiFlopInitDevice(
// Allocate request sense buffer. // Allocate request sense buffer.
// //
#ifndef __REACTOS__
senseData = ExAllocatePool(NonPagedPoolNxCacheAligned, SENSE_BUFFER_SIZE); senseData = ExAllocatePool(NonPagedPoolNxCacheAligned, SENSE_BUFFER_SIZE);
#else
senseData = ExAllocatePool(NonPagedPoolCacheAligned, SENSE_BUFFER_SIZE);
#endif
if (senseData == NULL) { if (senseData == NULL) {
@ -1160,11 +1162,7 @@ Return Value:
// //
Irp->IoStatus.Information = 0; Irp->IoStatus.Information = 0;
#ifndef __REACTOS__
srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE); srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE);
#else
srb = ExAllocatePool(NonPagedPool, SCSI_REQUEST_BLOCK_SIZE);
#endif
if (srb == NULL) { if (srb == NULL) {
@ -1530,11 +1528,7 @@ Return Value:
// Determine if the device is writable. // Determine if the device is writable.
// //
#ifndef __REACTOS__
modeData = ExAllocatePool(NonPagedPoolNxCacheAligned, MODE_DATA_SIZE); modeData = ExAllocatePool(NonPagedPoolNxCacheAligned, MODE_DATA_SIZE);
#else
modeData = ExAllocatePool(NonPagedPoolCacheAligned, MODE_DATA_SIZE);
#endif
if (modeData == NULL) { if (modeData == NULL) {
status = STATUS_INSUFFICIENT_RESOURCES; status = STATUS_INSUFFICIENT_RESOURCES;
@ -1845,20 +1839,12 @@ Return Value:
// Allocate a Srb for the read command. // Allocate a Srb for the read command.
// //
#ifndef __REACTOS__
readData = ExAllocatePool(NonPagedPoolNx, geometry->BytesPerSector); readData = ExAllocatePool(NonPagedPoolNx, geometry->BytesPerSector);
#else
readData = ExAllocatePool(NonPagedPool, geometry->BytesPerSector);
#endif
if (readData == NULL) { if (readData == NULL) {
return STATUS_NO_MEMORY; return STATUS_NO_MEMORY;
} }
#ifndef __REACTOS__
srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE); srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE);
#else
srb = ExAllocatePool(NonPagedPool, SCSI_REQUEST_BLOCK_SIZE);
#endif
if (srb == NULL) { if (srb == NULL) {
@ -1948,11 +1934,7 @@ Return Value:
return(diskData->DriveType); return(diskData->DriveType);
} }
#ifndef __REACTOS__
modeData = ExAllocatePool(NonPagedPoolNxCacheAligned, MODE_DATA_SIZE); modeData = ExAllocatePool(NonPagedPoolNxCacheAligned, MODE_DATA_SIZE);
#else
modeData = ExAllocatePool(NonPagedPoolCacheAligned, MODE_DATA_SIZE);
#endif
if (modeData == NULL) { if (modeData == NULL) {
return(DRIVE_TYPE_NONE); return(DRIVE_TYPE_NONE);
@ -2217,11 +2199,7 @@ Return Value:
PAGED_CODE(); PAGED_CODE();
#ifndef __REACTOS__
modeData = ExAllocatePool(NonPagedPoolNxCacheAligned, MODE_DATA_SIZE); modeData = ExAllocatePool(NonPagedPoolNxCacheAligned, MODE_DATA_SIZE);
#else
modeData = ExAllocatePool(NonPagedPoolCacheAligned, MODE_DATA_SIZE);
#endif
if (modeData == NULL) { if (modeData == NULL) {
return(STATUS_INSUFFICIENT_RESOURCES); return(STATUS_INSUFFICIENT_RESOURCES);
@ -2320,11 +2298,7 @@ Return Value:
// Allocate a Srb for the format command. // Allocate a Srb for the format command.
// //
#ifndef __REACTOS__
srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE); srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE);
#else
srb = ExAllocatePool(NonPagedPool, SCSI_REQUEST_BLOCK_SIZE);
#endif
if (srb == NULL) { if (srb == NULL) {
@ -2384,11 +2358,7 @@ Return Value:
// Allocate a Srb for the format command. // Allocate a Srb for the format command.
// //
#ifndef __REACTOS__
srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE); srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE);
#else
srb = ExAllocatePool(NonPagedPool, SCSI_REQUEST_BLOCK_SIZE);
#endif
if (srb == NULL) { if (srb == NULL) {
return(STATUS_INSUFFICIENT_RESOURCES); return(STATUS_INSUFFICIENT_RESOURCES);
@ -2514,13 +2484,8 @@ Return Value:
DebugPrint((2,"Sending SCSIOP_START_STOP_UNIT\n")); DebugPrint((2,"Sending SCSIOP_START_STOP_UNIT\n"));
#ifndef __REACTOS__
context = ExAllocatePool(NonPagedPoolNx, context = ExAllocatePool(NonPagedPoolNx,
sizeof(COMPLETION_CONTEXT)); sizeof(COMPLETION_CONTEXT));
#else
context = ExAllocatePool(NonPagedPool,
sizeof(COMPLETION_CONTEXT));
#endif
if (context == NULL) { if (context == NULL) {
@ -2599,11 +2564,7 @@ Return Value:
context = NULL; context = NULL;
if (!overFlow) { if (!overFlow) {
#ifndef __REACTOS__
context = ExAllocatePool(NonPagedPoolNx, sizeNeeded); context = ExAllocatePool(NonPagedPoolNx, sizeNeeded);
#else
context = ExAllocatePool(NonPagedPool, sizeNeeded);
#endif
} }
if (context == NULL) { if (context == NULL) {
@ -2765,11 +2726,7 @@ Return Value:
driveMediaConstants->SectorsPerTrack * driveMediaConstants->SectorsPerTrack *
driveMediaConstants->BytesPerSector; driveMediaConstants->BytesPerSector;
#ifndef __REACTOS__
buffer = ExAllocatePool(NonPagedPoolNxCacheAligned, length); buffer = ExAllocatePool(NonPagedPoolNxCacheAligned, length);
#else
buffer = ExAllocatePool(NonPagedPoolCacheAligned, length);
#endif
if (buffer == NULL) { if (buffer == NULL) {
return(STATUS_INSUFFICIENT_RESOURCES); return(STATUS_INSUFFICIENT_RESOURCES);
@ -3051,11 +3008,7 @@ Return Value:
// Allocate an SRB for the SCSIOP_READ_FORMATTED_CAPACITY request // Allocate an SRB for the SCSIOP_READ_FORMATTED_CAPACITY request
// //
#ifndef __REACTOS__
srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE); srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE);
#else
srb = ExAllocatePool(NonPagedPool, SCSI_REQUEST_BLOCK_SIZE);
#endif
if (srb == NULL) if (srb == NULL)
{ {
@ -3071,11 +3024,7 @@ Return Value:
ASSERT(dataTransferLength < 0x100); ASSERT(dataTransferLength < 0x100);
#ifndef __REACTOS__
dataBuffer = ExAllocatePool(NonPagedPoolNx, dataTransferLength); dataBuffer = ExAllocatePool(NonPagedPoolNx, dataTransferLength);
#else
dataBuffer = ExAllocatePool(NonPagedPool, dataTransferLength);
#endif
if (dataBuffer == NULL) if (dataBuffer == NULL)
{ {
@ -3425,11 +3374,7 @@ Return Value:
// Allocate an SRB for the SCSIOP_FORMAT_UNIT request // Allocate an SRB for the SCSIOP_FORMAT_UNIT request
// //
#ifndef __REACTOS__
srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE); srb = ExAllocatePool(NonPagedPoolNx, SCSI_REQUEST_BLOCK_SIZE);
#else
srb = ExAllocatePool(NonPagedPool, SCSI_REQUEST_BLOCK_SIZE);
#endif
if (srb == NULL) if (srb == NULL)
{ {
@ -3438,13 +3383,8 @@ Return Value:
// Allocate a transfer buffer for the SCSIOP_FORMAT_UNIT parameter list // Allocate a transfer buffer for the SCSIOP_FORMAT_UNIT parameter list
// //
#ifndef __REACTOS__
parameterList = ExAllocatePool(NonPagedPoolNx, parameterList = ExAllocatePool(NonPagedPoolNx,
sizeof(FORMAT_UNIT_PARAMETER_LIST)); sizeof(FORMAT_UNIT_PARAMETER_LIST));
#else
parameterList = ExAllocatePool(NonPagedPool,
sizeof(FORMAT_UNIT_PARAMETER_LIST));
#endif
if (parameterList == NULL) if (parameterList == NULL)
{ {
@ -3573,4 +3513,3 @@ Return Value:
return status; return status;
} }