Subversion Repositories Kolibri OS

Rev

Rev 1279 | Rev 1304 | 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: 1290 $
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]
20
        call    dword [servetable+edi*4]
21
        ret
593 mikedld 22
 
671 Ghost 23
 
1 ha 24
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
25
;;                                                            ;;
1055 Galkov 26
;;                     SYSENTER ENTRY                         ;;
1 ha 27
;;                                                            ;;
28
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
6 poddubny 29
 
1055 Galkov 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
671 Ghost 40
 
1055 Galkov 41
        movzx   eax, al
42
        call    dword [servetable2 + eax * 4]
43
 
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
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
65
        movzx   eax, al
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:
412 serge 77
  ;     cli                 syscall clear IF
1055 Galkov 78
        xchg    esp, [ss:tss._esp0]
79
        push    ecx
80
        lea     ecx, [esp+4]
81
        xchg    ecx, [ss:tss._esp0]
82
        sti
83
        push    ecx
84
        mov     ecx, [ecx]
85
        ;------------------
86
        pushad
87
        cld
375 Ghost 88
 
1055 Galkov 89
        movzx   eax, al
90
        call    dword [servetable2 + eax * 4]
375 Ghost 91
 
1055 Galkov 92
        popad
93
        ;------------------
94
        mov     ecx, [ss:esp+4]
95
        pop     esp
96
        sysret
97
 
1 ha 98
iglobal
99
  ;;;;;;;;;;;;;;;;;;;;;;;;;;;;
100
  ;; SYSTEM FUNCTIONS TABLE ;;
101
  ;;;;;;;;;;;;;;;;;;;;;;;;;;;;
102
 
103
  align 4
104
  servetable:
105
 
671 Ghost 106
      dd 0
107
      dd 0
108
      dd 0
109
      dd 0
110
      dd 0
111
      dd 0
112
      dd 0
113
      dd 0
114
      dd 0
115
      dd 0
116
      dd 0
684 diamond 117
      dd 0
118
      dd 0
119
      dd 0
120
      dd 0
121
      dd 0
122
      dd 0
123
      dd 0
124
      dd 0
125
      dd 0
671 Ghost 126
      dd 0
1276 Lrz 127
      dd 0
128
      dd 0
1279 Lrz 129
      dd 0
1290 Lrz 130
      dd 0                       ; 24-PlayCdTrack,StopCd and GetCdPlaylist
1276 Lrz 131
      dd 0                       ; 25
132
      dd 0			 ; 26
671 Ghost 133
      dd 0
802 serge 134
      dd 0                       ;
671 Ghost 135
      dd 0
1055 Galkov 136
      dd sys_current_directory   ; 30-Get/SetCurrentDirectory
671 Ghost 137
      dd 0
138
      dd 0
139
      dd 0
140
      dd 0
766 Rus 141
      dd 0
142
      dd 0
1290 Lrz 143
      dd 0                       ; 37-GetMousePosition_ScreenRelative,.
940 serge 144
      dd 0                       ; 38-DrawLine
145
      dd sys_getbackground       ; 39-GetBackgroundSize,ReadBgrData,.
671 Ghost 146
      dd 0
742 Rus 147
      dd 0
765 Rus 148
      dd 0
940 serge 149
      dd sys_outport             ; 43-SendDeviceData
765 Rus 150
      dd 0
151
      dd 0
1 ha 152
      dd syscall_reserveportarea ; 46-ReservePortArea and FreePortArea
940 serge 153
      dd display_number          ; 47-WriteNum
154
      dd display_settings        ; 48-SetRedrawType and SetButtonType
155
      dd sys_apm                 ; 49-Advanced Power Management (APM)
1055 Galkov 156
      dd random_shaped_window    ; 50-Window shape & scale
940 serge 157
      dd syscall_threads         ; 51-Threads
158
      dd stack_driver_stat       ; 52-Stack driver status
159
      dd socket                  ; 53-Socket interface
671 Ghost 160
      dd 0
940 serge 161
      dd sound_interface         ; 55-Sound interface
671 Ghost 162
      dd 0
940 serge 163
      dd sys_pcibios             ; 57-PCI BIOS32
164
      dd file_system             ; 58-Common file system interface
671 Ghost 165
      dd 0
940 serge 166
      dd sys_IPC                 ; 60-Inter Process Communication
167
      dd sys_gs                  ; 61-Direct graphics access
168
      dd sys_pci                 ; 62-PCI functions
169
      dd sys_msg_board           ; 63-System message board
1055 Galkov 170
      dd sys_resize_app_memory   ; 64-Resize application memory usage
283 diamond 171
      dd syscall_putimage_palette; 65-PutImagePalette
940 serge 172
      dd sys_process_def         ; 66-Process definitions - keyboard
173
      dd sys_window_move         ; 67-Window move or resize
174
      dd f68                     ; 68-Some internal services
175
      dd sys_debug_services      ; 69-Debug
176
      dd file_system_lfn         ; 70-Common file system interface, version 2
114 mikedld 177
      dd syscall_windowsettings  ; 71-Window settings
1 ha 178
 
671 Ghost 179
  ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
180
  ;; NEW SYSTEM FUNCTIONS TABLE ;;
181
  ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
182
  align 4
183
  servetable2:
1 ha 184
 
924 serge 185
      dd sys_drawwindow          ; 0-DrawWindow
186
      dd syscall_setpixel        ; 1-SetPixel
187
      dd sys_getkey              ; 2-GetKey
188
      dd sys_clock               ; 3-GetTime
189
      dd syscall_writetext       ; 4-WriteText
190
      dd delay_hs                ; 5-DelayHs
684 diamond 191
      dd syscall_openramdiskfile ; 6-OpenRamdiskFile
924 serge 192
      dd syscall_putimage        ; 7-PutImage
193
      dd sys_button              ; 8-DefineButton
194
      dd sys_cpuusage            ; 9-GetProcessInfo
195
      dd sys_waitforevent        ; 10-WaitForEvent
196
      dd sys_getevent            ; 11-CheckForEvent
197
      dd sys_redrawstat          ; 12-BeginDraw and EndDraw
198
      dd syscall_drawrect        ; 13-DrawRect
1055 Galkov 199
      dd syscall_getscreensize   ; 14-GetScreenSize
924 serge 200
      dd sys_background          ; 15-bgr
1055 Galkov 201
      dd sys_cachetodiskette     ; 16-FlushFloppyCache
924 serge 202
      dd sys_getbutton           ; 17-GetButton
203
      dd sys_system              ; 18-System Services
204
      dd paleholder              ; 19-reserved
1276 Lrz 205
      dd sys_midi                ; 20-ResetMidi and OutputMidi
206
      dd sys_setup               ; 21-SetMidiBase,SetKeymap,SetShiftKeymap,.
1279 Lrz 207
      dd sys_settime 	         ; 22-setting date,time,clock and alarm-clock
671 Ghost 208
      dd sys_wait_event_timeout  ; 23-TimeOutWaitForEvent
1290 Lrz 209
      dd syscall_cdaudio         ; 24-PlayCdTrack,StopCd and GetCdPlaylist
802 serge 210
      dd undefined_syscall       ; 25-reserved
1276 Lrz 211
      dd sys_getsetup            ; 26-GetMidiBase,GetKeymap,GetShiftKeymap,.
924 serge 212
      dd undefined_syscall       ; 27-reserved
802 serge 213
      dd undefined_syscall       ; 28-reserved
924 serge 214
      dd sys_date                ; 29-GetDate
215
      dd cross_order             ; 30-Get/SetCurrentDirectory
216
      dd undefined_syscall       ; 31-reserved
217
      dd undefined_syscall       ; 32-reserved
218
      dd undefined_syscall       ; 33-reserved
219
      dd undefined_syscall       ; 34-reserved
220
      dd syscall_getpixel        ; 35-GetPixel
221
      dd syscall_getarea         ; 36-GetArea
1290 Lrz 222
      dd readmousepos            ; 37-GetMousePosition_ScreenRelative,.
924 serge 223
      dd syscall_drawline        ; 38-DrawLine
224
      dd cross_order             ; 39-GetBackgroundSize,ReadBgrData,.
225
      dd set_app_param           ; 40-WantEvents
1055 Galkov 226
      dd syscall_getirqowner     ; 41-GetIrqOwner
924 serge 227
      dd get_irq_data            ; 42-ReadIrqData
228
      dd cross_order             ; 43-SendDeviceData
229
      dd sys_programirq          ; 44-ProgramIrqs
230
      dd reserve_free_irq        ; 45-ReserveIrq and FreeIrq
231
      dd cross_order             ; 46-ReservePortArea and FreePortArea
232
      dd cross_order             ; 47-WriteNum
233
      dd cross_order             ; 48-SetRedrawType and SetButtonType
234
      dd cross_order             ; 49-Advanced Power Management (APM)
235
      dd cross_order             ; 50-Window shape & scale
236
      dd cross_order             ; 51-Threads
237
      dd cross_order             ; 52-Stack driver status
238
      dd cross_order             ; 53-Socket interface
239
      dd undefined_syscall       ; 54-reserved
240
      dd cross_order             ; 55-Sound interface
241
      dd undefined_syscall       ; 56-reserved
242
      dd cross_order             ; 57-PCI BIOS32
243
      dd cross_order             ; 58-Common file system interface
244
      dd undefined_syscall       ; 59-reserved
245
      dd cross_order             ; 60-Inter Process Communication
246
      dd cross_order             ; 61-Direct graphics access
247
      dd cross_order             ; 62-PCI functions
248
      dd cross_order             ; 63-System message board
249
      dd cross_order             ; 64-Resize application memory usage
250
      dd cross_order             ; 65-PutImagePalette
251
      dd cross_order             ; 66-Process definitions - keyboard
252
      dd cross_order             ; 67-Window move or resize
253
      dd cross_order             ; 68-Some internal services
254
      dd cross_order             ; 69-Debug
255
      dd cross_order             ; 70-Common file system interface, version 2
256
      dd cross_order             ; 71-Window settings
1055 Galkov 257
      dd sys_sendwindowmsg       ; 72-Send window message
258
        times 255 - ( ($-servetable2) /4 )  dd undefined_syscall
259
      dd sys_end                 ; -1-end application
802 serge 260
 
1 ha 261
endg