Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

269 lines
5.7 KiB

/*** CreatF.C - Utility functions for Win 32 Cache Flusher.
*
*
* Title:
* CreatF - Create File Utility Routines
*
* Copyright (c) 1993, Microsoft Corporation.
* HonWah Chan.
*
*
* Description:
*
* This file includes all the utility functions used by the Win 32
* Create File. (CreatF.c)
*
*
* Design/Implementation Notes:
*
*
* Modification History:
* 93.05.17 HonWahChan -- created
*
*/
/* * * * * * * * * * * * * I N C L U D E F I L E S * * * * * * * * * * */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <malloc.h>
#include <nt.h>
#include <ntrtl.h>
#include <nturtl.h>
#include <windows.h>
/* * * * * * * * * * G L O B A L D E C L A R A T I O N S * * * * * * * * */
#include "Creatfil.h"
/* * * * * * * * * * F U N C T I O N P R O T O T Y P E S * * * * * * * * */
#include "Creatf.h"
/* * * * * * * * * * * G L O B A L V A R I A B L E S * * * * * * * * * */
/* none */
/* * * * * * E X P O R T E D G L O B A L V A R I A B L E S * * * * * */
/* none */
/******************************* F a i l e d *******************************
*
* Failed(rc, lpstrFname, lineno, lpstrMsg) -
* Checks the RC for an error type if an error has occured,
* prints the appropriate error message. It logs the error
* message to the testlog file.
*
* ENTRY rc - return code from the last API call
* lpstrFname - contains file name of where error occured
* lineno - contains line number of failed API call
* lpstrMsg - contains a general purpose message about the error
*
* EXIT -none-
*
* RETURN TRUE - if API failed
* FALSE - if API successful
*
* WARNING:
* -none-
*
* COMMENT:
* -none-
*
*/
BOOL Failed (RC rc, LPSTR lpstrFname, WORD lineno, LPSTR lpstrMsg)
{
LPSTR lpstrErrMsg;
if (rc != STATUS_SUCCESS) {
switch (rc) {
case (NTSTATUS)STATUS_INVALID_PARAMETER:
lpstrErrMsg = "Invalid parameter";
break;
case STATUS_TIMEOUT:
lpstrErrMsg = "TimeOut occured";
break;
case STATUS_INVALID_HANDLE:
lpstrErrMsg = "Invalid handle";
break;
case STATUS_BUFFER_OVERFLOW:
lpstrErrMsg = "Buffer overflow";
break;
case STATUS_ABANDONED:
lpstrErrMsg = "Object abandoned";
break;
case ERROR_NOT_ENOUGH_MEMORY:
lpstrErrMsg = "Not enough memory";
break;
case INPUTARGS_ERR:
lpstrErrMsg = "Invalid number of input arguments";
break;
case FILESIZE_ERR:
lpstrErrMsg = "Invalid file size argument";
break;
case INSUFMEM_ERR:
lpstrErrMsg = "Insufficient Memory";
break;
case FCLOSE_ERR:
lpstrErrMsg = "fclose() failed";
break;
case FOPEN_ERR:
lpstrErrMsg = "fopen() failed";
break;
case FSEEK_ERR:
lpstrErrMsg = "fseek() failed";
break;
case FWRITE_ERR:
lpstrErrMsg = "WriteFile() failed";
break;
default:
lpstrErrMsg = "";
} /* switch(rc) */
printf(" **************************\n");
printf(" * FAILure --> Line=%d File=%s (pid=0x%lX tid=0x%lX)\n",
lineno, lpstrFname, GetCurrentProcessId(),
GetCurrentThreadId());
printf(" * RC=0x%lX (%s)\n", rc, lpstrErrMsg);
printf(" * %s\n", lpstrMsg);
printf(" **************************\n");
return(TRUE);
} /* if(rc..) */
return(FALSE);
} /* Failed() */
/************************** D i s p l a y U s a g e ************************
*
* DisplayUsage() -
* Displays usgae for Create File
*
* ENTRY -none-
*
* EXIT -none-
*
* RETURN -none-
*
* WARNING:
* -none-
*
* COMMENT:
* -none-
*
*/
void DisplayUsage (void)
{
printf("\nUsage: CreatFil <FileName> <FileSize>\n");
printf(" CreatFil - Create a file with the specified File name with the specified file sizes in bytes\n");
return;
} /* DisplayUsage() */
/*
* MemoryAllocate() -
* Allocate a memory with the specified size
*
* ENTRY dwSize - size of buffer to be allocated
*
* EXIT -none-
*
* RETURN -none-
*
* WARNING:
* -none-
*
* COMMENT:
* -none-
*
*/
LPVOID MemoryAllocate (DWORD dwSize)
{ // MemoryAllocate
HGLOBAL hMemory ;
LPVOID lpMemory ;
hMemory = GlobalAlloc (GHND, dwSize) ;
if (!hMemory)
return (NULL) ;
lpMemory = GlobalLock (hMemory) ;
if (!lpMemory)
GlobalFree (hMemory) ;
return (lpMemory) ;
} // MemoryAllocate
/*
* MemoryFree() -
* Free a previously allocated memory.
*
* ENTRY lpMemory - Buffer address to be freeed
*
* EXIT -none-
*
* RETURN -none-
*
* WARNING:
* -none-
*
* COMMENT:
* -none-
*
*/
VOID MemoryFree (LPVOID lpMemory)
{ // MemoryFree
HGLOBAL hMemory ;
if (!lpMemory)
return ;
hMemory = GlobalHandle (lpMemory) ;
if (hMemory)
{ // if
GlobalUnlock (hMemory) ;
GlobalFree (hMemory) ;
} // if
} // MemoryFree