Add bouncing logo demo.
[bertos.git] / emul / emul.cpp
index d3336c68f645bde74c8181c157ed3b74491d5f61..9be4ed23071f03c35451683e581217897d507aff 100755 (executable)
 
 /*#*
  *#* $Log$
+ *#* 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.
+ *#*
  *#* Revision 1.2  2006/01/16 03:51:51  bernie
  *#* Fix boilerplate.
  *#*
 
 #include "emul.h"
 #include "emulwin.h"
+#include <cfg/module.h>
+
+#include <appconfig.h>
+#if CONFIG_KERNEL
+       #include <config_kern.h>
+#endif
+
 
-#include <qapplication.h>
 #include <cstdlib> // std::exit()
 
+#if _QT < 4
+       #include <qapplication.h>
+#else
+       #include <QtGui/qapplication.h>
+#endif
+
+
 /// 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))
 {
-       emulApp->setMainWidget(emulWin);
+       #if QT_VERSION < ((4 << 16) + (0 << 8) + 0)
+               emulApp->setMainWidget(emulWin);
+       #endif
        emulWin->show();
 }
 
@@ -49,7 +81,7 @@ Emulator::~Emulator()
 }
 
 
-void Emulator::quit()
+NORETURN void Emulator::quit()
 {
        // WHAT A KLUDGE!
        this->~Emulator();
@@ -59,19 +91,27 @@ void Emulator::quit()
        exit(0);
 }
 
+MOD_DEFINE(emul)
 
 /// Main emulator entry point.
 extern "C" void emul_init(int *argc, char *argv[])
 {
-       ASSERT(!emul);
-
        // 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);
 }
 
 extern "C" void emul_cleanup()
 {
-       ASSERT(emul);
+       MOD_CLEANUP(emul);
+
        delete emul;
        emul = NULL;
 }