Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. Qt crash on attach dll
Forum Update on Monday, May 27th 2025

Qt crash on attach dll

Scheduled Pinned Locked Moved Unsolved General and Desktop
14 Posts 4 Posters 1.7k Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • ? Offline
    ? Offline
    A Former User
    wrote on 23 Oct 2018, 21:36 last edited by
    #1

    Hello! So i've got the following code going inside a dll (c++)

    int myLibraryExec() {
    	char appName[] = "Project";
    	char *an = appName;
    	int argc = 0;
    	QApplication app(argc, &an);
    	app.exec();
    	return 0;
    }
    
    int mainFunction() {
    	if (console.allocateConsole()) {
    		std::cout << "Successful Injection!" << std::endl;
    	}
    	std::cout << "Trying" << std::endl;
    	int app = myLibraryExec();
    	std::cout << "xd" << std::endl;
    	return 0;
    }
    
    
    BOOL APIENTRY DllMain(HMODULE hModule,
    	DWORD  ul_reason_for_call,
    	LPVOID lpReserved
    )
    {
    	if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
    		hThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)mainFunction, (LPVOID)hModule, 0, NULL);
    		if (hThread == NULL) {
    			return 0;
    		}
    	}
    	else if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
    	}
    	else if (ul_reason_for_call == DLL_PROCESS_DETACH) {
    	}
    	else if (ul_reason_for_call == DLL_THREAD_DETACH) {
    	}
    	return TRUE;
    }
    
    
    

    It compiles fine, but when i try to attach it to a process to make sure it works, it crashes at the QApplication line, it never gets to exec().

    Any help would be appreciated.

    J 1 Reply Last reply 23 Oct 2018, 21:41
    0
    • ? A Former User
      23 Oct 2018, 21:36

      Hello! So i've got the following code going inside a dll (c++)

      int myLibraryExec() {
      	char appName[] = "Project";
      	char *an = appName;
      	int argc = 0;
      	QApplication app(argc, &an);
      	app.exec();
      	return 0;
      }
      
      int mainFunction() {
      	if (console.allocateConsole()) {
      		std::cout << "Successful Injection!" << std::endl;
      	}
      	std::cout << "Trying" << std::endl;
      	int app = myLibraryExec();
      	std::cout << "xd" << std::endl;
      	return 0;
      }
      
      
      BOOL APIENTRY DllMain(HMODULE hModule,
      	DWORD  ul_reason_for_call,
      	LPVOID lpReserved
      )
      {
      	if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
      		hThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)mainFunction, (LPVOID)hModule, 0, NULL);
      		if (hThread == NULL) {
      			return 0;
      		}
      	}
      	else if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
      	}
      	else if (ul_reason_for_call == DLL_PROCESS_DETACH) {
      	}
      	else if (ul_reason_for_call == DLL_THREAD_DETACH) {
      	}
      	return TRUE;
      }
      
      
      

      It compiles fine, but when i try to attach it to a process to make sure it works, it crashes at the QApplication line, it never gets to exec().

      Any help would be appreciated.

      J Offline
      J Offline
      JonB
      wrote on 23 Oct 2018, 21:41 last edited by
      #2

      @Mehodin
      http://doc.qt.io/qt-5/qapplication.html#QApplication

      In addition, argc must be greater than zero

      ? Did you mean int argc = 1; ?

      1 Reply Last reply
      0
      • ? Offline
        ? Offline
        A Former User
        wrote on 23 Oct 2018, 21:41 last edited by
        #3

        @JonB that crashes aswel

        J 1 Reply Last reply 23 Oct 2018, 21:42
        0
        • ? A Former User
          23 Oct 2018, 21:41

          @JonB that crashes aswel

          J Offline
          J Offline
          JonB
          wrote on 23 Oct 2018, 21:42 last edited by
          #4

          @Mehodin
          That was quick to test! Gotta start somewhere... :)

          1 Reply Last reply
          0
          • ? Offline
            ? Offline
            A Former User
            wrote on 23 Oct 2018, 21:44 last edited by
            #5

            thank you, yeah @JonB i had already tried that haha. tried it again after i replied to make sure.

            int mainFunction() {
            	if (console.allocateConsole()) {
            		std::cout << "Successful Attachment!" << std::endl;
            	}
            	char appName[] = "Project";
            	char *an = appName;
            	int argc = 1;
            	QApplication app(argc, &an);
            	app.exec();
            	return 0;
            }
            
            
            J 1 Reply Last reply 23 Oct 2018, 21:46
            0
            • ? A Former User
              23 Oct 2018, 21:44

              thank you, yeah @JonB i had already tried that haha. tried it again after i replied to make sure.

              int mainFunction() {
              	if (console.allocateConsole()) {
              		std::cout << "Successful Attachment!" << std::endl;
              	}
              	char appName[] = "Project";
              	char *an = appName;
              	int argc = 1;
              	QApplication app(argc, &an);
              	app.exec();
              	return 0;
              }
              
              
              J Offline
              J Offline
              JonB
              wrote on 23 Oct 2018, 21:46 last edited by JonB
              #6

              @Mehodin
              Humor me:

              int argc = 1;
              char *argv[] = { appname, 0 };
              QApplication app(argc, argv);
              
              1 Reply Last reply
              0
              • ? Offline
                ? Offline
                A Former User
                wrote on 23 Oct 2018, 21:49 last edited by
                #7

                worth a try, but didnt work lol @JonB

                1 Reply Last reply
                0
                • S Offline
                  S Offline
                  SGaist
                  Lifetime Qt Champion
                  wrote on 23 Oct 2018, 21:55 last edited by
                  #8

                  Hi,

                  Did you check the stack trace ?

                  You should check the solution provided in this stackoverflow thread.

                  Interested in AI ? www.idiap.ch
                  Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                  1 Reply Last reply
                  1
                  • H Offline
                    H Offline
                    hskoglund
                    wrote on 23 Oct 2018, 22:28 last edited by
                    #9

                    Hi, one problem though: you're launching a QApplication inside your DLL's DLLMain using a CreateThread call and that is a risky business at best, usually it crashes :-( See more here about what is supported by Windows inside a DLLMain

                    1 Reply Last reply
                    1
                    • ? Offline
                      ? Offline
                      A Former User
                      wrote on 23 Oct 2018, 23:05 last edited by A Former User
                      #10

                      @hskoglund @SGaist heyhey, so i tried that but i can't seem to figure out where MainWindow comes from, so i turned it into a QMainWindow

                      But it still crashes...

                      Doesn't matter whether i call it inside the CreateThread or outside of it...

                      static struct Data {
                      	int argc = 1;
                      	char *argv[2] = { strdup("dummy"), {} };
                      	QApplication app{ argc, argv };
                      	QMainWindow win;
                      } *d;
                      
                      static void startup() {
                      	d = new Data;
                      	d->win.show();
                      	d->app.processEvents();
                      }
                      
                      static void shutdown() {
                      	delete d;
                      }
                      
                      int mainFunction() {
                      	if (console.allocateConsole()) {
                      		std::cout << "Successful Attachment!" << std::endl;
                      	}
                      	startup();
                      	return 0;
                      }
                      
                      
                      BOOL APIENTRY DllMain(HMODULE hModule,
                      	DWORD  ul_reason_for_call,
                      	LPVOID lpReserved
                      )
                      {
                      	if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
                      		hThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)mainFunction, (LPVOID)hModule, 0, NULL);
                      
                      		if (hThread == NULL) {
                      			return 0;
                      		}
                      	}
                      	else if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
                      	}
                      	else if (ul_reason_for_call == DLL_PROCESS_DETACH) {
                      	}
                      	else if (ul_reason_for_call == DLL_THREAD_DETACH) {
                      	}
                      	return TRUE;
                      }
                      

                      and

                      static struct Data {
                      	int argc = 1;
                      	char *argv[2] = { strdup("dummy"), {} };
                      	QApplication app{ argc, argv };
                      	QMainWindow win;
                      } *d;
                      
                      static void startup() {
                      	d = new Data;
                      	d->win.show();
                      	d->app.processEvents();
                      }
                      
                      static void shutdown() {
                      	delete d;
                      }
                      
                      int mainFunction() {
                      	if (console.allocateConsole()) {
                      		std::cout << "Successful Attachment!" << std::endl;
                      	}
                      	return 0;
                      }
                      
                      
                      BOOL APIENTRY DllMain(HMODULE hModule,
                      	DWORD  ul_reason_for_call,
                      	LPVOID lpReserved
                      )
                      {
                      	if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
                      		hThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)mainFunction, (LPVOID)hModule, 0, NULL);
                       	        startup();
                      		if (hThread == NULL) {
                      			return 0;
                      		}
                      	}
                      	else if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
                      	}
                      	else if (ul_reason_for_call == DLL_PROCESS_DETACH) {
                      	}
                      	else if (ul_reason_for_call == DLL_THREAD_DETACH) {
                      	}
                      	return TRUE;
                      }
                      
                      
                      
                      1 Reply Last reply
                      0
                      • H Offline
                        H Offline
                        hskoglund
                        wrote on 23 Oct 2018, 23:32 last edited by
                        #11

                        If you skip calling CreateThread(), remove the hThread variable and just call startup() does it still crash?

                        1 Reply Last reply
                        0
                        • ? Offline
                          ? Offline
                          A Former User
                          wrote on 23 Oct 2018, 23:42 last edited by
                          #12

                          @hskoglund yes, sadly it does.

                          #include "stdafx.h"
                          #include <iostream>
                          #include <stdio.h>
                          #include <stdlib.h>
                          #include <string> 
                          
                          #include "memoryManager.h"
                          #include "consoleManager.h"
                          #include "Addresses.h"
                          
                          #include <QtWidgets/QApplication>
                          #include <QtWidgets/QPushbutton>
                          #include <QtWidgets/QMainWindow>
                          
                          // DEFENITIONS
                          #define _CRT_SECURE_NO_DEPRECATE
                          
                          HANDLE hThread;
                          
                          memoryManager memory = memoryManager();
                          consoleManager console = consoleManager();
                          static struct Data {
                          	int argc = 1;
                          	char *argv[2] = { strdup("dummy"), {} };
                          	QApplication app{ argc, argv };//
                          	QMainWindow win;//
                          } *d;
                          
                          static void startup() {
                          	d = new Data;
                          	d->win.show();
                          	d->app.processEvents();
                          }
                          
                          static void shutdown() {
                          	delete d;
                          }
                          
                          int mainFunction() {
                          	if (console.allocateConsole()) {
                          		std::cout << "Successful Attachment!" << std::endl;
                          	}
                          	startup();
                          	return 0;
                          } 
                          
                          
                          BOOL APIENTRY DllMain(HMODULE hModule,
                          	DWORD  ul_reason_for_call,
                          	LPVOID lpReserved
                          )
                          {
                          	if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
                          		startup();
                          		//hThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)mainFunction, (LPVOID)hModule, 0, NULL);
                          		//if (hThread == NULL) {
                          		//	return 0;
                          		//}
                          	}
                          	else if (ul_reason_for_call == DLL_PROCESS_ATTACH) {
                          	}
                          	else if (ul_reason_for_call == DLL_PROCESS_DETACH) {
                          		shutdown();
                          	}
                          	else if (ul_reason_for_call == DLL_THREAD_DETACH) {
                          	}
                          	return TRUE;
                          }
                          
                          
                          

                          yes it does...

                          1 Reply Last reply
                          0
                          • ? Offline
                            ? Offline
                            A Former User
                            wrote on 24 Oct 2018, 00:21 last edited by
                            #13

                            Anyone has an idea?...

                            1 Reply Last reply
                            0
                            • S Offline
                              S Offline
                              SGaist
                              Lifetime Qt Champion
                              wrote on 24 Oct 2018, 21:08 last edited by
                              #14

                              Again: what about the stack trace ?

                              Interested in AI ? www.idiap.ch
                              Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                              1 Reply Last reply
                              1

                              7/14

                              23 Oct 2018, 21:49

                              • Login

                              • Login or register to search.
                              7 out of 14
                              • First post
                                7/14
                                Last post
                              0
                              • Categories
                              • Recent
                              • Tags
                              • Popular
                              • Users
                              • Groups
                              • Search
                              • Get Qt Extensions
                              • Unsolved