]> git.proxmox.com Git - qemu.git/blame - TODO
full system SPARC emulation (Blue Swirl)
[qemu.git] / TODO
CommitLineData
728c9fd5
FB
1short term:
2----------
52c00a5f
FB
3- physical memory cache (reduce qemu-fast address space size to about 32 MB)
4- better code fetch (different exception handling + CS.limit support)
5- do not resize vga if invalid size.
6- avoid looping if only exceptions
67b915a5 7- handle fast timers + add explicit clocks
50691463 8- cycle counter for all archs
2be3bc02
FB
9- TLB code protection support for PPC
10- add sysenter/sysexit and fxsr for L4 pistachio 686
11- basic VGA optimizations
52c00a5f 12- disable SMC handling for ARM/SPARC/PPC (not finished)
2be3bc02 13- see undefined flags for BTx insn
82c7e2a4
FB
14- user/kernel PUSHL/POPL in helper.c
15- keyboard output buffer filling timing emulation
3d4b4c0f 16- return UD exception if LOCK prefix incorrectly used
82c7e2a4 17- test ldt limit < 7 ?
285dc330 18- tests for each target CPU
411bffc4 19- fix CCOP optimisation
df0f11a0
FB
20- fix all remaining thread lock issues (must put TBs in a specific invalid
21 state, find a solution for tb_flush()).
4690764b 22- fix arm fpu rounding (at least for float->integer conversions)
728c9fd5 23- SMP support
df0f11a0
FB
24
25lower priority:
26--------------
52c00a5f 27- HDD geometry in CMOS (not used except for very old DOS programs)
728c9fd5
FB
28- suppress shift_mem ops
29- fix some 16 bit sp push/pop overflow (pusha/popa, lcall lret)
30- sysenter/sysexit emulation
50691463 31- optimize FPU operations (evaluate x87 stack pointer statically)
285dc330 32- add IPC syscalls
411bffc4
FB
33- use -msoft-float on ARM
34- use kernel traps for unaligned accesses on ARM ?
df0f11a0
FB
35- handle rare page fault cases (in particular if page fault in heplers or
36 in syscall emulation code).
3c51961e 37- fix thread stack freeing (use kernel 2.5.x CLONE_CHILD_CLEARTID)
b03c60f3
FB
38- more syscalls (in particular all 64 bit ones, IPCs, fix 64 bit
39 issues, fix 16 bit uid issues)
df0f11a0
FB
40- use page_unprotect_range in every suitable syscall to handle all
41 cases of self modifying code.
42- use gcc as a backend to generate better code (easy to do by using
43 op-i386.c operations as local inline functions).
44- add SSE2/MMX operations