Subversion Repositories Kolibri OS

Rev

Rev 1551 | Rev 1599 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
431 serge 1
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2
;;                                                              ;;
3
;; Copyright (C) KolibriOS team 2004-2007. All rights reserved. ;;
4
;; Distributed under terms of the GNU General Public License    ;;
5
;;                                                              ;;
6
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
7
 
593 mikedld 8
$Revision: 1587 $
9
 
671 Ghost 10
; Old style system call converter
11
align 16
12
cross_order:
1055 Galkov 13
        ; load all registers in crossed order
14
        mov     eax, ebx
15
        mov     ebx, ecx
16
        mov     ecx, edx
17
        mov     edx, esi
18
        mov     esi, edi
19
        movzx   edi, byte[esp+28 + 4]
1551 art_zh 20
	  sub	    edi, 53		; all zeroes before
1055 Galkov 21
        call    dword [servetable+edi*4]
22
        ret
593 mikedld 23
 
1 ha 24
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
25
;;                                                            ;;
1055 Galkov 26
;;                     SYSENTER ENTRY                         ;;
1551 art_zh 27
;;                                  (not used on AMD systems) ;;
1 ha 28
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
6 poddubny 29
 
1551 art_zh 30
;align 32
31
;sysenter_entry:
32
;        ; Настраиваем стек
33
;        mov     esp, [ss:tss._esp0]
34
;        sti
35
;        push    ebp                     ; save app esp + 4
36
;        mov     ebp, [ebp]              ; ebp - original ebp
37
;        ;------------------
38
;        pushad
39
;        cld
40
;
41
;        movzx   eax, al
42
;        call    dword [servetable2 + eax * 4]
671 Ghost 43
 
1551 art_zh 44
;       popad
45
;       ;------------------
46
;       xchg    ecx, [ss:esp]           ; в вершин стека - app ecx, ecx - app esp + 4
47
;        sub     ecx, 4
48
;        xchg    edx, [ecx]              ; edx - return point, & save original edx
49
;        push    edx
50
;        mov     edx, [ss:esp + 4]
51
;        mov     [ecx + 4], edx          ; save original ecx
52
;        pop     edx
53
;        sysexit
1055 Galkov 54
 
375 Ghost 55
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
56
;;                                                            ;;
1055 Galkov 57
;;                   SYSTEM CALL ENTRY                        ;;
375 Ghost 58
;;                                                            ;;
59
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
60
 
1055 Galkov 61
align 16
62
i40:
63
        pushad
64
        cld
1551 art_zh 65
        and   eax, 0x07F
1055 Galkov 66
        call    dword [servetable2 + eax * 4]
67
        popad
68
        iretd
375 Ghost 69
 
70
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
71
;;                                                            ;;
72
;;                     SYSCALL ENTRY                          ;;
73
;;                                                            ;;
74
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
75
align 32
76
syscall_entry:
1551 art_zh 77
;       push    ecx
78
	  sti
79
        xor   eax, 3
80
        call    dword [servetable3 + eax * 4]
375 Ghost 81
 
1551 art_zh 82
;       pop     ecx
1055 Galkov 83
        sysret
84
 
1 ha 85
iglobal
86
  ;;;;;;;;;;;;;;;;;;;;;;;;;;;;
87
  ;; SYSTEM FUNCTIONS TABLE ;;
88
  ;;;;;;;;;;;;;;;;;;;;;;;;;;;;
89
 
90
  align 4
91
  servetable:
92
 
940 serge 93
      dd socket                  ; 53-Socket interface
671 Ghost 94
      dd 0
95
      dd 0
1375 Lrz 96
      dd 0
1496 Lrz 97
      dd 0
940 serge 98
      dd file_system             ; 58-Common file system interface
671 Ghost 99
      dd 0
1496 Lrz 100
      dd 0
1497 Lrz 101
      dd 0
1587 Lrz 102
      dd 0;sys_pci                 ; 62-PCI functions
940 serge 103
      dd sys_msg_board           ; 63-System message board
1 ha 104
 
671 Ghost 105
  ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
106
  ;; NEW SYSTEM FUNCTIONS TABLE ;;
107
  ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
108
  align 4
109
  servetable2:
1 ha 110
 
1391 mikedld 111
      dd syscall_draw_window     ; 0-DrawWindow
924 serge 112
      dd syscall_setpixel        ; 1-SetPixel
113
      dd sys_getkey              ; 2-GetKey
114
      dd sys_clock               ; 3-GetTime
115
      dd syscall_writetext       ; 4-WriteText
116
      dd delay_hs                ; 5-DelayHs
684 diamond 117
      dd syscall_openramdiskfile ; 6-OpenRamdiskFile
924 serge 118
      dd syscall_putimage        ; 7-PutImage
1334 mikedld 119
      dd syscall_button          ; 8-DefineButton
924 serge 120
      dd sys_cpuusage            ; 9-GetProcessInfo
121
      dd sys_waitforevent        ; 10-WaitForEvent
122
      dd sys_getevent            ; 11-CheckForEvent
123
      dd sys_redrawstat          ; 12-BeginDraw and EndDraw
124
      dd syscall_drawrect        ; 13-DrawRect
1055 Galkov 125
      dd syscall_getscreensize   ; 14-GetScreenSize
924 serge 126
      dd sys_background          ; 15-bgr
1055 Galkov 127
      dd sys_cachetodiskette     ; 16-FlushFloppyCache
924 serge 128
      dd sys_getbutton           ; 17-GetButton
129
      dd sys_system              ; 18-System Services
130
      dd paleholder              ; 19-reserved
1276 Lrz 131
      dd sys_midi                ; 20-ResetMidi and OutputMidi
132
      dd sys_setup               ; 21-SetMidiBase,SetKeymap,SetShiftKeymap,.
1279 Lrz 133
      dd sys_settime 	         ; 22-setting date,time,clock and alarm-clock
671 Ghost 134
      dd sys_wait_event_timeout  ; 23-TimeOutWaitForEvent
1290 Lrz 135
      dd syscall_cdaudio         ; 24-PlayCdTrack,StopCd and GetCdPlaylist
802 serge 136
      dd undefined_syscall       ; 25-reserved
1276 Lrz 137
      dd sys_getsetup            ; 26-GetMidiBase,GetKeymap,GetShiftKeymap,.
924 serge 138
      dd undefined_syscall       ; 27-reserved
802 serge 139
      dd undefined_syscall       ; 28-reserved
924 serge 140
      dd sys_date                ; 29-GetDate
1304 Lrz 141
      dd sys_current_directory   ; 30-Get/SetCurrentDirectory
924 serge 142
      dd undefined_syscall       ; 31-reserved
143
      dd undefined_syscall       ; 32-reserved
144
      dd undefined_syscall       ; 33-reserved
145
      dd undefined_syscall       ; 34-reserved
146
      dd syscall_getpixel        ; 35-GetPixel
147
      dd syscall_getarea         ; 36-GetArea
1290 Lrz 148
      dd readmousepos            ; 37-GetMousePosition_ScreenRelative,.
924 serge 149
      dd syscall_drawline        ; 38-DrawLine
1304 Lrz 150
      dd sys_getbackground       ; 39-GetBackgroundSize,ReadBgrData,.
924 serge 151
      dd set_app_param           ; 40-WantEvents
1055 Galkov 152
      dd syscall_getirqowner     ; 41-GetIrqOwner
924 serge 153
      dd get_irq_data            ; 42-ReadIrqData
1304 Lrz 154
      dd sys_outport             ; 43-SendDeviceData
924 serge 155
      dd sys_programirq          ; 44-ProgramIrqs
156
      dd reserve_free_irq        ; 45-ReserveIrq and FreeIrq
1306 Lrz 157
      dd syscall_reserveportarea ; 46-ReservePortArea and FreePortArea
1369 Lrz 158
      dd display_number          ; 47-WriteNum
1362 mikedld 159
      dd syscall_display_settings ; 48-SetRedrawType and SetButtonType
1330 Lrz 160
      dd sys_apm		 ; 49-Advanced Power Management (APM)
1369 Lrz 161
      dd syscall_set_window_shape ; 50-Window shape & scale
162
      dd syscall_threads         ; 51-Threads
163
      dd stack_driver_stat       ; 52-Stack driver status
924 serge 164
      dd cross_order             ; 53-Socket interface
165
      dd undefined_syscall       ; 54-reserved
1496 Lrz 166
      dd sound_interface	 ; 55-Sound interface
924 serge 167
      dd undefined_syscall       ; 56-reserved
1375 Lrz 168
      dd sys_pcibios             ; 57-PCI BIOS32
924 serge 169
      dd cross_order             ; 58-Common file system interface
170
      dd undefined_syscall       ; 59-reserved
1496 Lrz 171
      dd sys_IPC		 ; 60-Inter Process Communication
1497 Lrz 172
      dd sys_gs			 ; 61-Direct graphics access
1587 Lrz 173
      dd pci_api;cross_order             ; 62-PCI functions
924 serge 174
      dd cross_order             ; 63-System message board
1306 Lrz 175
      dd sys_resize_app_memory   ; 64-Resize application memory usage
1495 Lrz 176
      dd sys_putimage_palette    ; 65-PutImagePalette
1494 Lrz 177
      dd sys_process_def         ; 66-Process definitions - keyboard
1391 mikedld 178
      dd syscall_move_window     ; 67-Window move or resize
1345 Lrz 179
      dd f68			 ; 68-Some internal services
1329 Lrz 180
      dd sys_debug_services      ; 69-Debug
1491 Lrz 181
      dd file_system_lfn         ; 70-Common file system interface, version 2
1391 mikedld 182
      dd syscall_window_settings ; 71-Window settings
1055 Galkov 183
      dd sys_sendwindowmsg       ; 72-Send window message
1551 art_zh 184
        times 127 - ( ($-servetable2) /4 )  dd undefined_syscall
1055 Galkov 185
      dd sys_end                 ; -1-end application
802 serge 186
 
1551 art_zh 187
align 4
188
servetable3:
189
 
190
	dd 	paleholder	; 0
191
	dd 	paleholder	; 1
192
	dd 	paleholder	; 2
193
	dd 	sys_end	; last
194
 
1 ha 195
endg