Idea: Implement Concurrent GC on the windows Platform

rikki cattermole rikki at cattermole.co.nz
Sun Jan 13 18:20:38 UTC 2019


It does not look like this is a viable option.

I could not get a remote thread created. Code below for anyone else that 
wants to have a play. On my machine it'll crash with error 5 trying to 
create a thread.

---

import std.stdio;
import core.sys.windows.basetsd;
import core.sys.windows.windows;
import core.thread;

extern(Windows) {
     alias HPSS = HANDLE;

     enum PSS_CAPTURE_FLAGS {
         PSS_CAPTURE_NONE                                = 0x00000000,
         PSS_CAPTURE_VA_CLONE                            = 0x00000001,
         PSS_CAPTURE_RESERVED_00000002                   = 0x00000002,
         PSS_CAPTURE_HANDLES                             = 0x00000004,
         PSS_CAPTURE_HANDLE_NAME_INFORMATION             = 0x00000008,
         PSS_CAPTURE_HANDLE_BASIC_INFORMATION            = 0x00000010,
         PSS_CAPTURE_HANDLE_TYPE_SPECIFIC_INFORMATION    = 0x00000020,
         PSS_CAPTURE_HANDLE_TRACE                        = 0x00000040,
         PSS_CAPTURE_THREADS                             = 0x00000080,
         PSS_CAPTURE_THREAD_CONTEXT                      = 0x00000100,
         PSS_CAPTURE_THREAD_CONTEXT_EXTENDED             = 0x00000200,
         PSS_CAPTURE_RESERVED_00000400                   = 0x00000400,
         PSS_CAPTURE_VA_SPACE                            = 0x00000800,
         PSS_CAPTURE_VA_SPACE_SECTION_INFORMATION        = 0x00001000,
         PSS_CAPTURE_IPT_TRACE                           = 0x00002000,

         PSS_CREATE_BREAKAWAY_OPTIONAL                   = 0x04000000,
         PSS_CREATE_BREAKAWAY                            = 0x08000000,
         PSS_CREATE_FORCE_BREAKAWAY                      = 0x10000000,
         PSS_CREATE_USE_VM_ALLOCATIONS                   = 0x20000000,
         PSS_CREATE_MEASURE_PERFORMANCE                  = 0x40000000,
         PSS_CREATE_RELEASE_SECTION                      = 0x80000000
     }

     enum PSS_QUERY_INFORMATION_CLASS {
         PSS_QUERY_PROCESS_INFORMATION = 0,
         PSS_QUERY_VA_CLONE_INFORMATION = 1,
         PSS_QUERY_AUXILIARY_PAGES_INFORMATION = 2,
         PSS_QUERY_VA_SPACE_INFORMATION = 3,
         PSS_QUERY_HANDLE_INFORMATION = 4,
         PSS_QUERY_THREAD_INFORMATION = 5,
         PSS_QUERY_HANDLE_TRACE_INFORMATION = 6,
         PSS_QUERY_PERFORMANCE_COUNTERS = 7
     }

     struct PSS_VA_CLONE_INFORMATION {
         HANDLE VaCloneHandle;
     }

     DWORD GetProcessId(HANDLE);
     DWORD PssCaptureSnapshot(HANDLE, PSS_CAPTURE_FLAGS, DWORD, HPSS*);
     DWORD PssQuerySnapshot(HPSS, PSS_QUERY_INFORMATION_CLASS, void*, 
DWORD);
     DWORD PssFreeSnapshot(HANDLE, HPSS);
}

__gshared Thread someThread;

void main() {
     writeln("Hello from host");

     HPSS snapshotRef;
     DWORD status = PssCaptureSnapshot(GetCurrentProcess(),
         PSS_CAPTURE_FLAGS.PSS_CAPTURE_VA_CLONE,
         CONTEXT_ALL, &snapshotRef);
     writeln("status 1: ", status);
     assert(status == 0);

     readln;

     PSS_VA_CLONE_INFORMATION cloneInfo;
     status = PssQuerySnapshot(snapshotRef, 
PSS_QUERY_INFORMATION_CLASS.PSS_QUERY_VA_CLONE_INFORMATION, &cloneInfo, 
PSS_VA_CLONE_INFORMATION.sizeof);
     writeln("status 2: ", status);
     assert(status == 0);
     writeln(GetProcessId(cloneInfo.VaCloneHandle));
     readln;

     HANDLE remoteThreadRef = 
CreateRemoteThread(cloneInfo.VaCloneHandle, null, 0, &threadFuncInit, 
null, CREATE_SUSPENDED, null);
     writeln("status 3: ", GetLastError());
     assert(remoteThreadRef !is null);

     readln;
     status = PssFreeSnapshot(GetCurrentProcess(), snapshotRef);
     writeln("status 4: ", status);

}

void threadFunc() {
     writeln("Hi from thread!");
}

extern(Windows) {
     uint threadFuncInit(void*) {
         writeln("WHAT???");
         stdout.flush;
         someThread = new Thread(&threadFunc);
         someThread.start;
         return 0;
     }
}


More information about the Digitalmars-d mailing list