/*++ Copyright (c) 1990 Microsoft Corporation Module Name: tprofile.c Abstract: User-mode test for profile object. Note, this will be added to TEX.C Author: Lou Perazzoli (loup) 24-Sep-1990 Revision History: --*/ #include main() { HANDLE Profile, Profile2; ULONG Hack; PULONG Buffer; HANDLE CurrentProcessHandle; ULONG Size1; NTSTATUS status; Buffer = &Hack; CurrentProcessHandle = NtCurrentProcess(); status = NtCreateProfile (&Profile, CurrentProcessHandle, NULL, 0xFFFFFFFF, 16, Buffer, (ULONG)64*1024, ProfileTime, (KAFFINITY)-1); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) create profile #1 failed - status %lx\n", status); } status = NtStartProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) start profile #1 failed - status %lx\n", status); } status = NtStopProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) stop profile #1 failed - status %lx\n", status); } Size1 = 1024*64; Buffer = NULL; status = NtAllocateVirtualMemory (CurrentProcessHandle, (PVOID *)&Buffer, 0, &Size1, MEM_RESERVE | MEM_COMMIT, PAGE_READWRITE); // // This should fail as buffersize is too small. // status = NtCreateProfile (&Profile, NtCurrentProcess(), NULL, 0xFFFFFFFF, 16, Buffer, (ULONG)64*1024, ProfileTime, (KAFFINITY)-1); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) create profile #2 failed - status %lx\n", status); } status = NtStartProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) start profile #2 failed - status %lx\n", status); } status = NtStopProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) stop profile #2 failed - status %lx\n", status); } status = NtClose (Profile); // // This should succeed. // status = NtCreateProfile (&Profile, NtCurrentProcess(), NULL, 0xFFFFFFFF, 18, Buffer, (ULONG)64*1024, ProfileTime, (KAFFINITY)-1); if (status != STATUS_SUCCESS) { DbgPrint("(Unexpected) create profile #3 failed - status %lx\n", status); } status = NtStartProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Unexpected) start profile #3 failed - status %lx\n", status); } status = NtStopProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Unexpected) stop profile #3 failed - status %lx\n", status); } status = NtClose (Profile); // // Attempt to create a profile that can't work because the // address range is too big. // status = NtCreateProfile (&Profile, NtCurrentProcess(), (PVOID)0x203030, 0xffffffff, 6, Buffer, (ULONG)64*1024, ProfileTime, (KAFFINITY)-1); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) create profile #4 failed - status %lx\n", status); } status = NtStartProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) start profile #4 failed - status %lx\n", status); } status = NtStopProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) stop profile #4 failed - status %lx\n", status); } status = NtClose (Profile); // // Attempt to create a sucessful profile. // status = NtCreateProfile (&Profile, NtCurrentProcess(), (PVOID)0x80000000, 0x7fffffff, 17, Buffer, (ULONG)64*1024, ProfileTime, (KAFFINITY)-1); if (status != STATUS_SUCCESS) { DbgPrint("(Unexpected) create profile #5 failed - status %lx\n", status); } status = NtStartProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Unexpected) start profile #5 failed - status %lx\n", status); } status = NtStopProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Unexpected) stop profile #5 failed - status %lx\n", status); } // // now start it again. // status = NtStartProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Unexpected) start profile #6.1 failed - status %lx\n", status); } // // now start it again, should fail. // status = NtStartProfile (Profile); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) start profile #6.2 failed - status %lx\n", status); } // // now create another one (using the same buffer). // status = NtCreateProfile (&Profile2, NtCurrentProcess(), NULL, 0x3000000, 15, Buffer, (ULONG)64*1024, ProfileTime, (KAFFINITY)-1); if (status != STATUS_SUCCESS) { DbgPrint("create profile #7 failed - status %lx\n", status); } status = NtStartProfile (Profile2); if (status != STATUS_SUCCESS) { DbgPrint("start profile #7.1 failed - status %lx\n", status); } status = NtStopProfile (Profile2); if (status != STATUS_SUCCESS) { DbgPrint("stop profile #7.2 failed - status %lx\n", status); } status = NtStopProfile (Profile2); if (status != STATUS_SUCCESS) { DbgPrint("(Expected) stop profile #7.3 failed - status %lx\n", status); } status = NtStartProfile (Profile2); if (status != STATUS_SUCCESS) { DbgPrint("start profile #7.4 failed - status %lx\n", status); } status = NtClose (Profile); if (status != STATUS_SUCCESS) { DbgPrint("close profile #7.5 failed - status %lx\n", status); } return status; }