Sistema l'errore da me commesso in fase di conversione...
[bertos.git] / emul / emul.cpp
old mode 100755 (executable)
new mode 100644 (file)
index b6cf30f..0603f85
 
 /*#*
  *#* $Log$
+ *#* Revision 1.6  2006/05/28 12:17:57  bernie
+ *#* Drop almost all the Qt3 cruft.
+ *#*
+ *#* Revision 1.5  2006/05/27 22:30:56  bernie
+ *#* Add some delay to slow things down.
+ *#*
+ *#* Revision 1.4  2006/02/24 01:35:40  bernie
+ *#* Update for new emulator.
+ *#*
  *#* Revision 1.3  2006/02/20 02:00:40  bernie
  *#* Port to Qt 4.1.
  *#*
 #include "emulwin.h"
 #include <cfg/module.h>
 
+#include <appconfig.h>
+#if CONFIG_KERNEL
+       #include <config_kern.h>
+#endif
+
+
 #include <cstdlib> // std::exit()
 
-#if _QT < 4
-       #include <qapplication.h>
-#else
-       #include <QtGui/qapplication.h>
-#endif
+#include <QtGui/qapplication.h>
 
 
 /// The global emulator instance.
 Emulator *emul;
 
+#if CONFIG_KERNEL
+       #include <mware/list.h>
+
+       /// List of process stacks
+       List StackFreeList;
+
+       // HACK: Reserve 64KB of stack space for kernel processes
+       const int NPROC = 8;
+       int stacks[NPROC][(64 * 1024) / sizeof(int)];
+#endif
+
 Emulator::Emulator(int &argc, char **argv) :
        emulApp(new QApplication(argc, argv)),
        emulWin(new EmulWin(this))
 {
-       #if QT_VERSION < ((4 << 16) + (0 << 8) + 0)
-               emulApp->setMainWidget(emulWin);
-       #endif
        emulWin->show();
 }
 
@@ -79,6 +98,12 @@ extern "C" void emul_init(int *argc, char *argv[])
        // setup global emulator pointer
        emul = new Emulator(*argc, argv);
 
+#if CONFIG_KERNEL
+       LIST_INIT(&StackFreeList);
+       for (int i = 0; i < NPROC; i++)
+               ADDTAIL(&StackFreeList, (Node *)stacks[i]);
+#endif
+
        MOD_INIT(emul);
 }
 
@@ -94,5 +119,6 @@ extern "C" void emul_idle()
 {
        // We process GUI events when the application is idle.
        emul->emulApp->processEvents();
+       usleep(1000);
 }