Sistema l'errore da me commesso in fase di conversione...
[bertos.git] / emul / emul.cpp
old mode 100755 (executable)
new mode 100644 (file)
index c68fa8d..0603f85
@@ -3,7 +3,7 @@
  * <!--
  * Copyright 2006 Develer S.r.l. (http://www.develer.com/)
  * Copyright 2000, 2001 Bernardo Innocenti <bernie@codewiz.org>
- * All Rights Reserved.
+ * This file is part of DevLib - See README.devlib for information.
  * -->
  *
  * \version $Id$
 
 /*#*
  *#* $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.
+ *#*
+ *#* Revision 1.2  2006/01/16 03:51:51  bernie
+ *#* Fix boilerplate.
+ *#*
  *#* Revision 1.1  2006/01/16 03:37:12  bernie
  *#* Add emulator skeleton.
  *#*
 
 #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()
 
+#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))
 {
-       emulApp->setMainWidget(emulWin);
        emulWin->show();
 }
 
@@ -46,7 +80,7 @@ Emulator::~Emulator()
 }
 
 
-void Emulator::quit()
+NORETURN void Emulator::quit()
 {
        // WHAT A KLUDGE!
        this->~Emulator();
@@ -56,19 +90,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;
 }
@@ -77,5 +119,6 @@ extern "C" void emul_idle()
 {
        // We process GUI events when the application is idle.
        emul->emulApp->processEvents();
+       usleep(1000);
 }