Fixed binary search: no more infinite loops when vendor is unknown.
[tangerine.git] / arch / all-mingw32 / README.txt
blob52fc1745db7fb071b4397e6b1647880317201793
1  This file contains various notes about Windows-hosted port of AROS.
3  1. COMPILING
5  In order to compile it natively under Windows OS you need:
7 a) Working Cygwin environment (Mingw's MSYS is expected to work too but it's not tested).
8 b) Netpbm package of course.
9 c) Native gcc v3 (for Cygwin). In gcc v4 -mno-cygwin option is no more supported. If you use MSYS
10    you're free from this restriction.
11 d) AROS-targetted crosscompiler. Cygwin version of it can be found on AROS Archives:
12    http://archives.aros-exec.org/index.php?function=browse&cat=development/cross
13    Use the latest gcc version, however i386-aros-gcc v3 also works.
14 e) Mingw32 libraries package for Cygwin.
16  That's all. Execute "./configure --target=mingw32-i386", then "make".
18  At the moment native build is succesfully performed under cygwin using Cygwin's gcc v3.4.4 and
19 i386-aros-gcc v4.2.2. Building under MSYS is a work in progress.
21  You can also crosscompile it under other OS. The only restriction (implied by configure script,
22 needs to be fixed): build system CPU should be different from i386. Otherwise configure suggests native build
23 and attempts to use host's gcc as a kernel compiler (one that builds a bootstrap and helper DLLs). Of course
24 it won't work. For cross-compiling you need the same toolset as for native build, plus Mingw32-targetted
25 crosscompiler. Currently cross-build is succesfully performed on Linux/x86-64 using native gcc v4.1.2 and
26 both crosscompilers v4.2.2 (built from vanilla source tree).
28  2. RUNNING
30  In order to run AROS open a command line, go to root AROS directory ("AROS"), and run
31 "boot\AROSBootstrap.exe". This port behaves like UNIX-hosted, it uses emul.handler, which
32 makes your current directory to be root of your SYS:.
33  You can specify some options on the command line for bootstrap and AROS. Enter
34 "boot\AROSBootstrap.exe -h" to learn about them. --hostmem option currently does nothing.
36  3. HACKING
38  Here i'll describe how AROS should interact with host OS (Windows in our case). This is very tricky,
39 however it all ends up in two simple rules when you get the whole picture.
41  3.1. Two simple rules.
43  1. If you need to call some WinAPI functions, enclose the call (or several calls if you do them in a batch)
44 in Forbid()/Permit() pair. Otherwise you may get random sudden aborts (AROS just quits without any message).
45  2. Do not call any operations that would block (I/O to serial/parallel ports for example). From the Windows'
46 point of view the whole AROS is one thread. If you block it, the whole AROS gets non-responsive until it's
47 unblocked. No task scheduling will occur at all.
49  3.2. Performing wait operations in Windows.
51  Often it's needed to wait for some event on Windows side. A good example of this is handling keyboard and mouse.
52 You have to sit and wait until some message arrives. Another example could be serial port I/O (which can take rather
53 long time). Such things are implemented using virtual hardware (VH). A VH unit is represented by asynchronous Windows
54 thread that you create. You can use anything in order to talk to this thread. The simplest and most efficient way
55 to do it is having some structure in memory where you put the data and then signal to your VH thread to start working
56 somehow (for example by triggering an event or posting a message to its queue). While your thread works, AROS works too.
57 When your VH thread finishes its job, it should call KrnCauseIRQ() function from kernel_native.dll. This causes an IRQ
58 on AROS side and AROS can read back the data from your structure.
59  As you can see, this works exactly in the same way as real hardware.
60  Note that thread switching in Windows seems to be rather slow, so avoid using VH threads if possible (for example you
61 can use overlapped I/O with serial port, where Windows itself will play a role of VH thread, because in this case you
62 may directly specify an event to signal when the I/O completes). However corresponsind part in kernel_native.dll is not
63 designed yet (you can't get pointer to IRQ event object), but this will change as soon as someone needs it.
64  Look at wingdi.hidd source code for a good example of VH implementation.
66  3.3.In-depth description of AROS task scheduler implementation.
68  As you can see, Windows-hosted AROS acts very much like AROS on real hardware. In fact it's little simple virtual machine.
69 There are two Windows threads. One thread (let's call it "main thread") runs all AROS processes. In order to perform task
70 switching there is a second Windows thread, representing a "CPU" (let's call it VCPU - virtual CPU). It sits in a loop
71 waiting for several objects (these objects are emulated hardware IRQs). The first of them is a periodic 50Hz waitable timer,
72 it's the heart of the VM. Its IRQ is responsible for generating VBLANK interrupt in exec and counting quantums (this is also
73 done in exec.library on AROS side). when any IRQ happens, VCPU stops main thread and remembers its CPU context. It's a supervisor
74 mode, from this thread AROS interrupt handlers are called. After all processing it looks if task switching should be done.
75 If yes, VCPU substitutes the context of main thread with the context of next scheduled AROS process. Then it resumes main thread.
76  As a result, single Windowsthread runs all AROS processes in turn (actually this thread represents user mode of virtual CPU).
77  This is why it's necessary to enclose WinAPI calls in Forbid()/Permit() pair. Windows probably attempts to protect itself from
78 hackers this way and keeps an eye on thread's context (mostly stack) during execution of a system call. If task switch occurs
79 while main thread is inside a sycall (it's actually paused by Windows in this state), context swap happens. The syscall notices
80 that the stack changes and silently aborts the whole process. As a result, AROS just silently quits without any error messages.
81  Task switcher can be also run manually by RaiseException() WinAPI call. This happens inside exec's Cause(), and is responsible
82 for causing SoftInts.
83  All other objects which VCPU waits on are simple triggerable events. They are triggered by KrnCauseIRQ() and are used by various
84 drivers in order to communicate with VH threads. Currently their allocation is static, but dynamic allocation is really needed and
85 will be implemented in future.
86  For more details see kernel.resource, i hope the code is clear enough.
88  11.03.2009, Pavel Fedin <sonic.amiga@gmail.com>