Subversion Repositories Kolibri OS

Rev

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