win32 port (initial patch by kazu)
[qemu] / TODO
1 short term:
2 ----------
3 - handle fast timers + add explicit clocks
4 - OS/2 install bug
5 - win 95 install bug
6 - handle Self Modifying Code even if modifying current TB (BE OS 5 install)
7 - physical memory cache (reduce qemu-fast address space size to about 32 MB)
8 - better code fetch
9 - XP security bug
10 - cycle counter for all archs
11 - TLB code protection support for PPC
12 - add sysenter/sysexit and fxsr for L4 pistachio 686
13 - basic VGA optimizations
14 - disable SMC handling for ARM/SPARC/PPC
15 - see undefined flags for BTx insn
16 - user/kernel PUSHL/POPL in helper.c
17 - keyboard output buffer filling timing emulation
18 - return UD exception if LOCK prefix incorrectly used
19 - cmos clock update and timers
20 - test ldt limit < 7 ?
21 - tests for each target CPU
22 - fix CCOP optimisation
23 - fix all remaining thread lock issues (must put TBs in a specific invalid
24   state, find a solution for tb_flush()).
25 - fix arm fpu rounding (at least for float->integer conversions)
26 - SMP support
27
28 lower priority:
29 --------------
30 - suppress shift_mem ops
31 - fix some 16 bit sp push/pop overflow (pusha/popa, lcall lret)
32 - sysenter/sysexit emulation
33 - optimize FPU operations (evaluate x87 stack pointer statically)
34 - add IPC syscalls
35 - use -msoft-float on ARM
36 - use kernel traps for unaligned accesses on ARM ?
37 - handle rare page fault cases (in particular if page fault in heplers or
38   in syscall emulation code).
39 - fix thread stack freeing (use kernel 2.5.x CLONE_CHILD_CLEARTID)
40 - more syscalls (in particular all 64 bit ones, IPCs, fix 64 bit
41   issues, fix 16 bit uid issues)
42 - use page_unprotect_range in every suitable syscall to handle all
43   cases of self modifying code.
44 - use gcc as a backend to generate better code (easy to do by using
45   op-i386.c operations as local inline functions).
46 - add SSE2/MMX operations