/*++ Copyright (c) 1990 Microsoft Corporation Module Name: tfile.c Abstract: Test program for Win32 Base File API calls Author: Mark Lucovsky (markl) 26-Sep-1990 Revision History: --*/ #include #include #include #include #include #include #include #include #include #include #define xassert ASSERT int izero; int i,j; #define BASESPIN 1000000 #define NULL_SERVER_SWITCHES 10000 #define PATH_CONVERSION_TEST 1000 // // Define local types. // typedef struct _PERFINFO { LARGE_INTEGER StartTime; LARGE_INTEGER StopTime; ULONG ContextSwitches; ULONG FirstLevelFills; ULONG SecondLevelFills; ULONG SystemCalls; PCHAR Title; ULONG Iterations; } PERFINFO, *PPERFINFO; VOID FinishBenchMark ( IN PPERFINFO PerfInfo ) { ULONG ContextSwitches; LARGE_INTEGER Duration; ULONG FirstLevelFills; ULONG Length; ULONG Performance; ULONG SecondLevelFills; NTSTATUS Status; ULONG SystemCalls; SYSTEM_PERFORMANCE_INFORMATION SystemInfo; // // Print results and announce end of test. // NtQuerySystemTime((PLARGE_INTEGER)&PerfInfo->StopTime); Status = NtQuerySystemInformation(SystemPerformanceInformation, (PVOID)&SystemInfo, sizeof(SYSTEM_PERFORMANCE_INFORMATION), NULL); if (NT_SUCCESS(Status) == FALSE) { printf("Failed to query performance information, status = %lx\n", Status); return; } Duration = RtlLargeIntegerSubtract(PerfInfo->StopTime, PerfInfo->StartTime); Length = Duration.LowPart / 10000; printf(" Test time in milliseconds %d\n", Length); printf(" Number of iterations %d\n", PerfInfo->Iterations); Performance = PerfInfo->Iterations * 1000 / Length; printf(" Iterations per second %d\n", Performance); ContextSwitches = SystemInfo.ContextSwitches - PerfInfo->ContextSwitches; FirstLevelFills = SystemInfo.FirstLevelTbFills - PerfInfo->FirstLevelFills; SecondLevelFills = SystemInfo.SecondLevelTbFills - PerfInfo->SecondLevelFills; SystemCalls = SystemInfo.SystemCalls - PerfInfo->SystemCalls; printf(" First Level TB Fills %d\n", FirstLevelFills); printf(" Second Level TB Fills %d\n", SecondLevelFills); printf(" Total Context Switches %d\n", ContextSwitches); printf(" Number of System Calls %d\n", SystemCalls); printf("*** End of Test ***\n\n"); return; } VOID StartBenchMark ( IN PCHAR Title, IN ULONG Iterations, IN PPERFINFO PerfInfo ) { NTSTATUS Status; SYSTEM_PERFORMANCE_INFORMATION SystemInfo; // // Announce start of test and the number of iterations. // printf("*** Start of test ***\n %s\n", Title); PerfInfo->Title = Title; PerfInfo->Iterations = Iterations; NtQuerySystemTime((PLARGE_INTEGER)&PerfInfo->StartTime); Status = NtQuerySystemInformation(SystemPerformanceInformation, (PVOID)&SystemInfo, sizeof(SYSTEM_PERFORMANCE_INFORMATION), NULL); if (NT_SUCCESS(Status) == FALSE) { printf("Failed to query performance information, status = %lx\n", Status); return; } PerfInfo->ContextSwitches = SystemInfo.ContextSwitches; PerfInfo->FirstLevelFills = SystemInfo.FirstLevelTbFills; PerfInfo->SecondLevelFills = SystemInfo.SecondLevelTbFills; PerfInfo->SystemCalls = SystemInfo.SystemCalls; return; } VOID ScrollTest() { COORD dest,cp; SMALL_RECT Sm; CHAR_INFO ci; CONSOLE_SCREEN_BUFFER_INFO sbi; HANDLE ScreenHandle; SMALL_RECT Window; GetConsoleScreenBufferInfo(GetStdHandle(STD_OUTPUT_HANDLE), &sbi); Window.Left = 0; Window.Top = 0; Window.Right = 79; Window.Bottom = 49; dest.X = 0; dest.Y = 0; ci.Char.AsciiChar = ' '; ci.Attributes = sbi.wAttributes; SetConsoleWindowInfo(GetStdHandle(STD_OUTPUT_HANDLE), TRUE, &Window); cp.X = 0; cp.Y = 0; Sm.Left = 0; Sm.Top = 1; Sm.Right = 79; Sm.Bottom = 49; ScrollConsoleScreenBuffer(GetStdHandle(STD_OUTPUT_HANDLE), &Sm, NULL, dest, &ci); } VOID WinWordOpenFileTest() { PERFINFO PerfInfo; ULONG Index; OFSTRUCT ofstr; HANDLE iFile; StartBenchMark("WinWord OpenFile)", 3, &PerfInfo); for ( Index=0;Index<3;Index++){ iFile = (HANDLE)OpenFile("foo",&ofstr, OF_PARSE); iFile = (HANDLE)OpenFile("E:\\xxxxxxx\\winword.ini",&ofstr, 0x20); iFile = (HANDLE)OpenFile("E:\\xxxxxxx\\perftest.doc",&ofstr, 0x22); iFile = (HANDLE)OpenFile("E:foo",&ofstr, OF_PARSE); iFile = (HANDLE)OpenFile("E:foo",&ofstr, OF_PARSE); iFile = (HANDLE)OpenFile("E:foo",&ofstr, OF_PARSE); iFile = (HANDLE)OpenFile("E:foo",&ofstr, OF_PARSE); iFile = (HANDLE)OpenFile("E:\\xxxxxxx\\custom.dic",&ofstr, 0x4022 ); iFile = (HANDLE)OpenFile("E:\\xxxxxxx\\sp_am.exc",&ofstr, 0x4040 ); iFile = (HANDLE)OpenFile("E:foo",&ofstr, OF_PARSE); iFile = (HANDLE)OpenFile("foo",&ofstr, OF_PARSE); iFile = (HANDLE)OpenFile("E:~doc3d08.tmp",&ofstr, 0x1022); iFile = (HANDLE)OpenFile("E:\\xxxxxxx\\tempx.doc",&ofstr, 0xa022 ); iFile = (HANDLE)OpenFile("E:\\xxxxxxx\\~$rftest.doc",&ofstr, 0x4012 ); iFile = (HANDLE)OpenFile("foo",&ofstr, OF_PARSE); iFile = (HANDLE)OpenFile("E:~doc391f.tmp",&ofstr, 0x1022); iFile = (HANDLE)OpenFile("E:\\xxxxxxx\\tempy.doc",&ofstr, 0xa022 ); iFile = (HANDLE)OpenFile("E:\\xxxxxxx\\winword.ini",&ofstr, 0x12); } FinishBenchMark(&PerfInfo); } VOID gettictst(int x) { PERFINFO PerfInfo; ULONG i,j; ULONG tnt,tw32; if ( !x ) { StartBenchMark("NtGetTickCount)", 100000, &PerfInfo); for ( i=0;i<100000;i++){ j = GetTickCount(); } FinishBenchMark(&PerfInfo); } else { while(1)GetTickCount(); } } VOID latst() { PERFINFO PerfInfo; ULONG i,j; HANDLE h1, h2, h3, h4, h5; StartBenchMark("LocalAlloc/Free)", 200, &PerfInfo); for ( i=0;i<200/5;i++){ h1 = LocalAlloc(0, 500); h2 = LocalAlloc(0, 600); h3 = LocalAlloc(0, 700); LocalFree(h2); h4 = LocalAlloc(0, 1000); h5 = LocalAlloc(0, 100); LocalFree(h1); LocalFree(h3); LocalFree(h4); LocalFree(h5); } FinishBenchMark(&PerfInfo); } VOID WinWordGetDriveTypeTest() { PERFINFO PerfInfo; ULONG Index,Reps; OFSTRUCT ofstr; HANDLE iFile; CHAR DiskName[4]; WCHAR WDiskName[4]; // StartBenchMark("WinWord GetDriveType (1-26)", // 26, // &PerfInfo); // // for ( Index=1;Index<27;Index++){ // GetDriveType(Index); // } // // FinishBenchMark(&PerfInfo); DiskName[0]='a'; DiskName[1]=':'; DiskName[2]='\\'; DiskName[3]='\0'; StartBenchMark("WinWord GetDriveTypeA (a-z)", 100, &PerfInfo); for(Reps=0;Reps<100;Reps++){ for ( Index=0;Index<26;Index++){ DiskName[0]='a'+Index; GetDriveTypeA(DiskName); } } FinishBenchMark(&PerfInfo); WDiskName[0]=(WCHAR)'a'; WDiskName[1]=(WCHAR)':'; WDiskName[2]=(WCHAR)'\\'; WDiskName[3]=(WCHAR)'\0'; StartBenchMark("WinWord GetDriveTypeW (a-z)", 100, &PerfInfo); for(Reps=0;Reps<100;Reps++){ for ( Index=0;Index<26;Index++){ WDiskName[0]=(WCHAR)'a'+Index; GetDriveTypeW(WDiskName); } } FinishBenchMark(&PerfInfo); } VOID BogusOrdinalTest() { HANDLE hBase; FARPROC z; WaitForSingleObject(0,-2); hBase = GetModuleHandle("base"); xassert(hBase); z = GetProcAddress(hBase,0x00001345); } VOID NullServerSwitchTest ( VOID ) { PERFINFO PerfInfo; NTSTATUS Status; ULONG Index; StartBenchMark("Null Server Call Benchmark)", NULL_SERVER_SWITCHES, &PerfInfo); for (Index = 0; Index < NULL_SERVER_SWITCHES; Index += 1) { CsrIdentifyAlertableThread(); } // // Print out performance statistics. // FinishBenchMark(&PerfInfo); return; } VOID PathConvertTest ( VOID ) { PERFINFO PerfInfo; NTSTATUS Status; ULONG Index; UNICODE_STRING FileName; BOOLEAN TranslationStatus; RTL_RELATIVE_NAME RelativeName; StartBenchMark("Path Conversion Test (foo)", PATH_CONVERSION_TEST, &PerfInfo); for (Index = 0; Index < PATH_CONVERSION_TEST; Index += 1) { RtlDosPathNameToNtPathName_U( L"foo", &FileName, NULL, &RelativeName ); RtlFreeHeap(RtlProcessHeap(),FileName.Buffer); } // // Print out performance statistics. // FinishBenchMark(&PerfInfo); StartBenchMark("Path Conversion Test (e:\\nt\\windows\\foo)", PATH_CONVERSION_TEST, &PerfInfo); for (Index = 0; Index < PATH_CONVERSION_TEST; Index += 1) { RtlDosPathNameToNtPathName_U( L"e:\\nt\\windows\\foo", &FileName, NULL, &RelativeName ); RtlFreeHeap(RtlProcessHeap(),FileName.Buffer); } // // Print out performance statistics. // FinishBenchMark(&PerfInfo); return; } z(){} bar() { for (i=0;i<2*BASESPIN;i++)j = i++; z(); z(); z(); z(); z(); z(); z(); z(); z(); z(); z(); z(); z(); z(); } foo() { for (i=0;i "); scanf("%s",buf); RtlInitAnsiString(&astr,buf); RtlAnsiStringToUnicodeString(&ustr,&astr,TRUE); dw = RtlIsDosDeviceName_U(ustr.Buffer); printf("dw %x Name %s \n",dw,buf); } typedef struct _CMDSHOW { WORD wMustBe2; WORD wShowWindowValue; } CMDSHOW, *PCMDSHOW; typedef struct _LOAD_MODULE_PARAMS { LPSTR lpEnvAddress; LPSTR lpCmdLine; PCMDSHOW lpCmdShow; DWORD dwReserved; } LOAD_MODULE_PARAMS, *PLOAD_MODULE_PARAMS; typedef DWORD (*PFNWAITFORINPUTIDLE)(HANDLE hProcess, DWORD dwMilliseconds); void cptst() { CHAR buf[256]; CHAR cline[256]; DWORD dw; STARTUPINFO StartupInfo; PROCESS_INFORMATION ProcessInformation; LOAD_MODULE_PARAMS lmp; CHAR Environment[256]; CMDSHOW cs; PFNWAITFORINPUTIDLE WaitForInputIdleRoutine; HANDLE hMod; hMod = LoadLibrary("user32"); WaitForInputIdleRoutine = GetProcAddress(hMod,"WaitForInputIdle"); printf("name -> "); scanf("%s",buf); RtlZeroMemory(&StartupInfo,sizeof(StartupInfo)); StartupInfo.cb = sizeof(StartupInfo); SetLastError(0); CreateProcess( NULL, buf, NULL, NULL, FALSE, 0, NULL, NULL, &StartupInfo, &ProcessInformation ); (WaitForInputIdleRoutine)(ProcessInformation.hProcess,10000); printf("GLE %d\n",GetLastError()); SetLastError(0); printf("WINEXEC %d\n",WinExec(buf,0)); SetLastError(0); lmp.lpEnvAddress = Environment; lmp.lpCmdLine = cline; lmp.dwReserved = 0; lmp.lpCmdShow = &cs; cs.wMustBe2 = 2; cs.wShowWindowValue = 3; cline[0] = strlen(buf); RtlMoveMemory(&cline[1],buf,cline[0]); cline[cline[0]+1] = 0x0d; printf("LOADMOD %d\n",LoadModule(buf,&lmp)); } void spawntst() { CHAR buf[256]; int i; printf("name -> "); scanf("%s",buf); i = _spawnlp(_P_WAIT,buf,"-l",NULL); } void badproctst() { CHAR buf[256]; DWORD dw; STARTUPINFO StartupInfo; PROCESS_INFORMATION ProcessInformation; LOAD_MODULE_PARAMS lmp; CHAR Environment[256]; CMDSHOW cs; printf("name -> "); scanf("%s",buf); RtlZeroMemory(&StartupInfo,sizeof(StartupInfo)); StartupInfo.cb = sizeof(StartupInfo); SetLastError(0); CreateProcess( NULL, buf, NULL, NULL, FALSE, 0, NULL, "*", &StartupInfo, &ProcessInformation ); printf("GLE %d\n",GetLastError()); } void copytst() { CHAR src[256]; CHAR dst[256]; BOOL b; printf("src -> "); scanf("%s",src); printf("dst -> "); scanf("%s",dst); b = CopyFile(src,dst,FALSE); } void fftst() { CHAR buf[256]; HANDLE fFile; WIN32_FIND_DATA FindFileData; BOOL b; printf("pattern -> "); scanf("%s",buf); fFile = FindFirstFile( buf, &FindFileData ); if ( fFile == INVALID_HANDLE_VALUE ){ printf("findfirst %s failed %d\n",buf,GetLastError()); return; } b = TRUE; while(b) { printf("0x%08x %08d %s\n", FindFileData.dwFileAttributes, FindFileData.nFileSizeLow, FindFileData.cFileName ); b = FindNextFile(fFile,&FindFileData); } FindClose(fFile); } void oftst() { OFSTRUCT OfStruct; HFILE rv; rv = OpenFile("",&OfStruct, OF_EXIST); printf("rv %d\n",rv); rv = OpenFile(NULL,&OfStruct, OF_EXIST); printf("rv %d\n",rv); rv = OpenFile(" ",&OfStruct, OF_EXIST); printf("rv %d\n",rv); } void spath() { char cbuff[512]; SearchPath( "c:\\nt;c:\\xytty;c:\\nt\\system", "kernel32", ".dll", 512, cbuff, NULL ); printf("%s\n",cbuff); } void muldivtst() { int answer,number,numerator,denom,result; PERFINFO PerfInfo; ULONG Index; StartBenchMark("MulDiv)", 50000, &PerfInfo); for(Index=0;Index<50000;Index++){ // // answer = -24 // number = -18; numerator = 96; denom = 72; answer = -24; result = MulDiv(number,numerator,denom); if ( answer != result ) printf("MulDiv(%ld,%ld,%ld)=%ld %s\n",number,numerator,denom,result,answer == result ? "SUCCESS" : "FAILED"); // // answer = -24 // number = 18; numerator = -96; denom = 72; answer = -24; result = MulDiv(number,numerator,denom); if ( answer != result ) printf("MulDiv(%ld,%ld,%ld)=%ld %s\n",number,numerator,denom,result,answer == result ? "SUCCESS" : "FAILED"); // // answer = 24 // number = -18; numerator = -96; denom = 72; answer = 24; result = MulDiv(number,numerator,denom); if ( answer != result ) printf("MulDiv(%ld,%ld,%ld)=%ld %s\n",number,numerator,denom,result,answer == result ? "SUCCESS" : "FAILED"); // // answer = -24 // number = -18; numerator = -96; denom = -72; answer = -24; result = MulDiv(number,numerator,denom); if ( answer != result ) printf("MulDiv(%ld,%ld,%ld)=%ld %s\n",number,numerator,denom,result,answer == result ? "SUCCESS" : "FAILED"); // // answer = -24 // number = -18; numerator = -96; denom = -72; answer = -24; result = MulDiv(number,numerator,denom); if ( answer != result ) printf("MulDiv(%ld,%ld,%ld)=%ld %s\n",number,numerator,denom,result,answer == result ? "SUCCESS" : "FAILED"); // // answer = 24 // number = 18; numerator = -96; denom = -72; answer = 24; result = MulDiv(number,numerator,denom); if ( answer != result ) printf("MulDiv(%ld,%ld,%ld)=%ld %s\n",number,numerator,denom,result,answer == result ? "SUCCESS" : "FAILED"); // // answer = 2 // number = 4; numerator = 2; denom = 5; answer = 2; result = MulDiv(number,numerator,denom); if ( answer != result ) printf("MulDiv(%ld,%ld,%ld)=%ld %s\n",number,numerator,denom,result,answer == result ? "SUCCESS" : "FAILED"); // // answer = 500 // number = 100; numerator = 10; denom = 2; answer = 500; result = MulDiv(number,numerator,denom); if ( answer != result ) printf("MulDiv(%ld,%ld,%ld)=%ld %s\n",number,numerator,denom,result,answer == result ? "SUCCESS" : "FAILED"); // // answer = 3b9aca00 // number = 1000000; numerator = 1000000; denom = 1000; answer = 0x3b9aca00; result = MulDiv(number,numerator,denom); if ( answer != result ) printf("MulDiv(%ld,%ld,%ld)=0x%lx %s\n",number,numerator,denom,result,answer == result ? "SUCCESS" : "FAILED"); } FinishBenchMark(&PerfInfo); } void dname() { UNICODE_STRING LinkName; UNICODE_STRING DeviceName; OBJECT_ATTRIBUTES Obja; HANDLE LinkHandle; NTSTATUS Status; ULONG i; PWCHAR p; WCHAR DeviceNameBuffer[MAXIMUM_FILENAME_LENGTH]; RtlInitUnicodeString(&LinkName,L"\\DosDevices\\A:"); p = (PWCHAR)LinkName.Buffer; p = p+12; for(i=0;i<26;i++){ *p = (WCHAR)'A'+i; InitializeObjectAttributes( &Obja, &LinkName, OBJ_CASE_INSENSITIVE, NULL, NULL ); Status = NtOpenSymbolicLinkObject( &LinkHandle, SYMBOLIC_LINK_QUERY, &Obja ); if (NT_SUCCESS( Status )) { // // Open succeeded, Now get the link value // DeviceName.Length = 0; DeviceName.MaximumLength = sizeof(DeviceNameBuffer); DeviceName.Buffer = DeviceNameBuffer; Status = NtQuerySymbolicLinkObject( LinkHandle, &DeviceName, NULL ); NtClose(LinkHandle); if ( NT_SUCCESS(Status) ) { printf("%wZ -> %wZ\n",&LinkName,&DeviceName); } } } } void mfextst() { MoveFileExW(L"C:\\tmp\\xx.xx", NULL, MOVEFILE_DELAY_UNTIL_REBOOT); } CRITICAL_SECTION cs; VOID StartBounce(PVOID pThreadBlockInfo) { EnterCriticalSection(&cs); Sleep(-1); } void lockuptst() { HANDLE hThread; DWORD id; InitializeCriticalSection(&cs); hThread = CreateThread( NULL, 0, (LPTHREAD_START_ROUTINE)StartBounce, 0, 0, &id ); EnterCriticalSection(&cs); Sleep(-1); } void getdisktst() { BOOL b; DWORD spc,bps,fc,tc; b = GetDiskFreeSpace(NULL,&spc,&bps,&fc,&tc); printf("GetDiskFreeSpace NULL %s\n",b ? "WORKED" : "FAILED" ); b = GetDiskFreeSpace("C:\\",&spc,&bps,&fc,&tc); printf("GetDiskFreeSpace C:\\ %s\n",b ? "WORKED" : "FAILED" ); b = GetDiskFreeSpace("C:\\WINNT\\",&spc,&bps,&fc,&tc); printf("GetDiskFreeSpace C:\\winnt\\ %s\n",b ? "WORKED" : "FAILED" ); } void DoChoice( int Choice ) { NTSTATUS Status; LONG *p; top: printf("exception test\n"); printf("1 Access Violation(r)\n"); printf("2 Access Violation(w)\n"); printf("3 Array Bounds \n"); printf("4 Int Divide By Zero\n"); printf("5 Software 0x77\n"); printf("6 bigpath\n"); printf("7 set default harderror\n"); printf("8 proftests\n"); printf("9 probetests\n"); printf("10 notifytests\n"); printf("11 openif\n"); printf("12 null server\n"); printf("13 path convert\n"); printf("14 bogus ordinal\n"); printf("15 winword openfile\n"); printf("16 scroll test\n"); printf("17 winword getdrivetype\n"); printf("18 dorip\n"); printf("19 Ofprompt\n"); printf("20 rtldevn\n"); printf("21 cptst\n"); printf("22 oftst\n"); printf("23 dname\n"); printf("24 fftst\n"); printf("25 copy\n"); printf("26 badproc\n"); printf("27 loadlib\n"); printf("28 gettictst(0)\n"); printf("29 latst\n"); printf("30 gettictst(1)\n"); printf("31 spath\n"); printf("32 spawntst\n"); printf("33 muldivtst\n"); printf("34 mfextst\n"); printf("35 lockuptst\n"); printf("36 getdisktst\n"); printf("Enter Choice --> "); scanf("%d",&Choice); printf("Good Choice... %d\n",Choice); switch ( Choice ) { case 1: SetErrorMode(SEM_NOGPFAULTERRORBOX); printf("Good Choice... %d\n",Choice); p = (int *)0xbaadadd0; Choice = *p; break; case 2: printf("Good Choice... %d\n",Choice); p = (int *)0xbaadadd0; *p = Choice; break; case 3: printf("Good Choice... %d\n",Choice); RtlRaiseStatus(STATUS_ARRAY_BOUNDS_EXCEEDED); break; case 4: printf("Good Choice... %d\n",Choice); Choice = Choice/izero; break; case 5: printf("Good Choice... %d\n",Choice); { UINT b; b = SetErrorMode(SEM_FAILCRITICALERRORS); xassert(b == 0); b = SetErrorMode(0); xassert(b == SEM_FAILCRITICALERRORS); } RtlRaiseStatus(0x77); break; case 6: printf("Good Choice... %d\n",Choice); { DWORD Bsize; DWORD Rsize; LPSTR Buff; LPSTR Ruff; DWORD Rvalue; LPSTR whocares; int i; printf("Enter Size --> "); scanf("%d",&Bsize); printf("Enter RSize --> "); scanf("%d",&Rsize); Buff = LocalAlloc(0,Bsize+1); xassert(Buff); Ruff = LocalAlloc(0,Bsize+1); xassert(Buff); RtlFillMemory(Buff,Bsize,'a'); Buff[0]='c'; Buff[1]=':'; Buff[2]='\\'; Buff[Bsize+1] = '\0'; Rvalue = GetFullPathName(Buff,Rsize,Ruff,&whocares); i = strcmp(Buff,Ruff); printf("Bsize %d Rsize %d Rvalue %d i=%d \n",Bsize,Rsize,Rvalue,i); } break; case 7: printf("Good Choice... %d\n",Choice); Status = NtSetDefaultHardErrorPort(NULL); xassert(Status == STATUS_PRIVILEGE_NOT_HELD); break; case 8: printf("Good Choice... %d\n",Choice); proftst(); break; case 9: printf("Good Choice... %d\n",Choice); probtst(); break; case 10: printf("Good Choice... %d\n",Choice); notifytst(); break; case 11: printf("Good Choice... %d\n",Choice); openiftst(); break; case 12: printf("Good Choice... %d\n",Choice); NullServerSwitchTest(); break; case 13: PathConvertTest(); break; case 14: BogusOrdinalTest(); break; case 15: WinWordOpenFileTest(); break; case 16: ScrollTest(); break; case 17: WinWordGetDriveTypeTest(); break; case 18: NewRip(0,"Just a warning\n"); NewRip(1,"We Are Hosed\n"); break; case 19: Ofprompt(); break; case 20: rtldevn(); break; case 21: cptst(); break; case 22: oftst(); break; case 23: dname(); break; case 24: fftst(); break; case 25: copytst(); break; case 26: badproctst(); break; case 27: { HANDLE hmods,hmodc,hmodw; hmods = LoadLibrary("shell32"); hmodc = LoadLibrary("cmd.exe"); hmodw = LoadLibrary("winspool.drv"); FreeLibrary(hmods); FreeLibrary(hmodc); FreeLibrary(hmodw); } break; case 28: gettictst(0); break; case 29: latst(); break; case 30: gettictst(1); break; case 31: spath(); break; case 32: spawntst(); break; case 33: muldivtst(); break; case 34: mfextst(); break; case 35: lockuptst(); break; case 36: getdisktst(); break; default: printf( "Bad choice: %d\n", Choice ); return; } return; } //#define NtCurrentTebAsm() {PTEB Teb;_asm{mov eax,fs:[0x24]};,Teb;} DWORD _cdecl main( int argc, char *argv[], char *envp[] ) { int Choice; char b[512]; // PTEB x; // // x = NtCurrentTebAsm(); GetDriveTypeW(L"A:\\"); xassert(SetThreadPriority(GetCurrentThread(),THREAD_PRIORITY_HIGHEST)); xassert(GetThreadPriority(GetCurrentThread()) == THREAD_PRIORITY_HIGHEST); xassert(SetThreadPriority(GetCurrentThread(),THREAD_PRIORITY_LOWEST)); xassert(GetThreadPriority(GetCurrentThread()) == THREAD_PRIORITY_LOWEST); xassert(SetThreadPriority(GetCurrentThread(),THREAD_PRIORITY_ABOVE_NORMAL)); xassert(GetThreadPriority(GetCurrentThread()) == THREAD_PRIORITY_ABOVE_NORMAL); xassert(SetThreadPriority(GetCurrentThread(),THREAD_PRIORITY_BELOW_NORMAL)); xassert(GetThreadPriority(GetCurrentThread()) == THREAD_PRIORITY_BELOW_NORMAL); xassert(SetThreadPriority(GetCurrentThread(),THREAD_PRIORITY_NORMAL)); xassert(GetThreadPriority(GetCurrentThread()) == THREAD_PRIORITY_NORMAL); xassert(SetThreadPriority(GetCurrentThread(),THREAD_PRIORITY_IDLE)); xassert(GetThreadPriority(GetCurrentThread()) == THREAD_PRIORITY_IDLE); xassert(SetThreadPriority(GetCurrentThread(),THREAD_PRIORITY_TIME_CRITICAL)); xassert(GetThreadPriority(GetCurrentThread()) == THREAD_PRIORITY_TIME_CRITICAL); xassert(SetThreadPriority(GetCurrentThread(),THREAD_PRIORITY_NORMAL)); xassert(GetThreadPriority(GetCurrentThread()) == THREAD_PRIORITY_NORMAL); xassert(!SetThreadPriority(GetCurrentThread(),THREAD_PRIORITY_HIGHEST+1)); xassert(GetThreadPriority(GetCurrentProcess()) == THREAD_PRIORITY_ERROR_RETURN); SetErrorMode(0); GetSystemDirectory(b,512); printf("%s\n",b); GetWindowsDirectory(b,512); printf("%s\n",b); printf("TEBSIZE %d\n",sizeof(TEB)); Choice = GetModuleFileName(NULL,b,512); if ( strlen(b) != Choice ) { printf("BAD strlen(b) = %d Choice %d b= %s\n",strlen(b),Choice,b); } else { printf("OK strlen(b) = %d Choice %d b= %s\n",strlen(b),Choice,b); } if (argc > 1) { while (--argc) { DoChoice( atoi( *++argv ) ); } } else { while (TRUE) { DoChoice( Choice ); } } //GetUserNameW(b,1); return 0; }