Rev 7327 | Rev 7830 | Go to most recent revision | Only display areas with differences | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 7327 | Rev 7828 | ||
---|---|---|---|
1 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
1 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
2 | ;; ;; |
2 | ;; ;; |
3 | ;; Copyright (C) KolibriOS team 2004-2015. All rights reserved. ;; |
3 | ;; Copyright (C) KolibriOS team 2004-2015. All rights reserved. ;; |
4 | ;; Distributed under terms of the GNU General Public License ;; |
4 | ;; Distributed under terms of the GNU General Public License ;; |
5 | ;; ;; |
5 | ;; ;; |
6 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
6 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
7 | 7 | ||
8 | $Revision: 7327 $ |
8 | $Revision: 7828 $ |
9 | 9 | ||
10 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
10 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
11 | ;; ;; |
11 | ;; ;; |
12 | ;; SYSENTER ENTRY ;; |
12 | ;; SYSENTER ENTRY ;; |
13 | ;; ;; |
13 | ;; ;; |
14 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
14 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
15 | 15 | ||
16 | align 32 |
16 | align 32 |
17 | sysenter_entry: |
17 | sysenter_entry: |
18 | ; Настраиваем стек |
18 | ; Настраиваем стек |
19 | mov esp, [ss:tss._esp0] |
19 | mov esp, [ss:tss._esp0] |
20 | sti |
20 | sti |
21 | push ebp ; save app esp + 4 |
21 | push ebp ; save app esp + 4 |
22 | mov ebp, [ebp] ; ebp - original ebp |
22 | mov ebp, [ebp] ; ebp - original ebp |
23 | ;------------------ |
23 | ;------------------ |
24 | pushad |
24 | pushad |
25 | cld |
25 | cld |
26 | 26 | ||
27 | call protect_from_terminate |
27 | call protect_from_terminate |
28 | 28 | ||
29 | movzx eax, byte [esp+28] |
29 | movzx eax, byte [esp+28] |
30 | mov edx, dword [esp+20] |
30 | mov edx, dword [esp+20] |
31 | call dword [servetable2 + eax * 4] |
31 | call dword [servetable2 + eax * 4] |
32 | 32 | ||
33 | call unprotect_from_terminate |
33 | call unprotect_from_terminate |
34 | popad |
34 | popad |
35 | ;------------------ |
35 | ;------------------ |
36 | xchg ecx, [ss:esp] ; в вершин стека - app ecx, ecx - app esp + 4 |
36 | xchg ecx, [ss:esp] ; в вершин стека - app ecx, ecx - app esp + 4 |
37 | sub ecx, 4 |
37 | sub ecx, 4 |
38 | xchg edx, [ecx] ; edx - return point, & save original edx |
38 | xchg edx, [ecx] ; edx - return point, & save original edx |
39 | push edx |
39 | push edx |
40 | mov edx, [ss:esp + 4] |
40 | mov edx, [ss:esp + 4] |
41 | mov [ecx + 4], edx ; save original ecx |
41 | mov [ecx + 4], edx ; save original ecx |
42 | pop edx |
42 | pop edx |
43 | sysexit |
43 | sysexit |
44 | 44 | ||
45 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
45 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
46 | ;; ;; |
46 | ;; ;; |
47 | ;; SYSTEM CALL ENTRY ;; |
47 | ;; SYSTEM CALL ENTRY ;; |
48 | ;; ;; |
48 | ;; ;; |
49 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
49 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
50 | 50 | ||
51 | align 16 |
51 | align 16 |
52 | i40: |
52 | i40: |
53 | pushad |
53 | pushad |
54 | cld |
54 | cld |
55 | call protect_from_terminate |
55 | call protect_from_terminate |
56 | movzx eax, byte [esp+28] |
56 | movzx eax, byte [esp+28] |
57 | mov edx, dword [esp+20] |
57 | mov edx, dword [esp+20] |
58 | call dword [servetable2 + eax * 4] |
58 | call dword [servetable2 + eax * 4] |
59 | call unprotect_from_terminate |
59 | call unprotect_from_terminate |
60 | popad |
60 | popad |
61 | iretd |
61 | iretd |
62 | 62 | ||
63 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
63 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
64 | ;; ;; |
64 | ;; ;; |
65 | ;; SYSCALL ENTRY ;; |
65 | ;; SYSCALL ENTRY ;; |
66 | ;; ;; |
66 | ;; ;; |
67 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
67 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
68 | align 32 |
68 | align 32 |
69 | syscall_entry: |
69 | syscall_entry: |
70 | ; cli syscall clear IF |
70 | ; cli syscall clear IF |
71 | xchg esp, [ss:tss._esp0] |
71 | xchg esp, [ss:tss._esp0] |
72 | push ecx |
72 | push ecx |
73 | lea ecx, [esp+4] |
73 | lea ecx, [esp+4] |
74 | xchg ecx, [ss:tss._esp0] |
74 | xchg ecx, [ss:tss._esp0] |
75 | sti |
75 | sti |
76 | push ecx |
76 | push ecx |
77 | mov ecx, [ecx] |
77 | mov ecx, [ecx] |
78 | ;------------------ |
78 | ;------------------ |
79 | pushad |
79 | pushad |
80 | cld |
80 | cld |
81 | call protect_from_terminate |
81 | call protect_from_terminate |
82 | 82 | ||
83 | movzx eax, byte [esp+28] |
83 | movzx eax, byte [esp+28] |
84 | mov edx, dword [esp+20] |
84 | mov edx, dword [esp+20] |
85 | call dword [servetable2 + eax * 4] |
85 | call dword [servetable2 + eax * 4] |
86 | 86 | ||
87 | call unprotect_from_terminate |
87 | call unprotect_from_terminate |
88 | popad |
88 | popad |
89 | ;------------------ |
89 | ;------------------ |
90 | mov ecx, [ss:esp+4] |
90 | mov ecx, [ss:esp+4] |
91 | pop esp |
91 | pop esp |
92 | sysret |
92 | sysret |
93 | 93 | ||
94 | iglobal |
94 | iglobal |
95 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
95 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
96 | ;; SYSTEM FUNCTIONS TABLE ;; |
96 | ;; SYSTEM FUNCTIONS TABLE ;; |
97 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
97 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
98 | align 4 |
98 | align 4 |
99 | servetable2: |
99 | servetable2: |
100 | 100 | ||
101 | dd syscall_draw_window ; 0-DrawWindow |
101 | dd syscall_draw_window ; 0-DrawWindow |
102 | dd syscall_setpixel ; 1-SetPixel |
102 | dd syscall_setpixel ; 1-SetPixel |
103 | dd sys_getkey ; 2-GetKey |
103 | dd sys_getkey ; 2-GetKey |
104 | dd sys_clock ; 3-GetTime |
104 | dd sys_clock ; 3-GetTime |
105 | dd syscall_writetext ; 4-WriteText |
105 | dd syscall_writetext ; 4-WriteText |
106 | dd delay_hs_unprotected ; 5-DelayHs |
106 | dd delay_hs_unprotected ; 5-DelayHs |
107 | dd undefined_syscall ; 6-deprecated OpenRamdiskFile |
107 | dd undefined_syscall ; 6-deprecated OpenRamdiskFile |
108 | dd syscall_putimage ; 7-PutImage |
108 | dd syscall_putimage ; 7-PutImage |
109 | dd syscall_button ; 8-DefineButton |
109 | dd syscall_button ; 8-DefineButton |
110 | dd sys_cpuusage ; 9-GetProcessInfo |
110 | dd sys_cpuusage ; 9-GetProcessInfo |
111 | dd sys_waitforevent ; 10-WaitForEvent |
111 | dd sys_waitforevent ; 10-WaitForEvent |
112 | dd sys_getevent ; 11-CheckForEvent |
112 | dd sys_getevent ; 11-CheckForEvent |
113 | dd sys_redrawstat ; 12-BeginDraw and EndDraw |
113 | dd sys_redrawstat ; 12-BeginDraw and EndDraw |
114 | dd syscall_drawrect ; 13-DrawRect |
114 | dd syscall_drawrect ; 13-DrawRect |
115 | dd syscall_getscreensize ; 14-GetScreenSize |
115 | dd syscall_getscreensize ; 14-GetScreenSize |
116 | dd sys_background ; 15-bgr |
116 | dd sys_background ; 15-bgr |
117 | dd sys_cachetodiskette ; 16-FlushFloppyCache |
117 | dd sys_cachetodiskette ; 16-FlushFloppyCache |
118 | dd sys_getbutton ; 17-GetButton |
118 | dd sys_getbutton ; 17-GetButton |
119 | dd sys_system ; 18-System Services |
119 | dd sys_system ; 18-System Services |
120 | dd paleholder ; 19-reserved |
120 | dd paleholder ; 19-reserved |
121 | dd sys_midi ; 20-ResetMidi and OutputMidi |
121 | dd sys_midi ; 20-ResetMidi and OutputMidi |
122 | dd sys_setup ; 21-SetMidiBase,SetKeymap,SetShiftKeymap,. |
122 | dd sys_setup ; 21-SetMidiBase,SetKeymap,SetShiftKeymap,. |
123 | dd sys_settime ; 22-setting date,time,clock and alarm-clock |
123 | dd sys_settime ; 22-setting date,time,clock and alarm-clock |
124 | dd sys_wait_event_timeout ; 23-TimeOutWaitForEvent |
124 | dd sys_wait_event_timeout ; 23-TimeOutWaitForEvent |
125 | dd syscall_cdaudio ; 24-PlayCdTrack,StopCd and GetCdPlaylist |
125 | dd syscall_cdaudio ; 24-PlayCdTrack,StopCd and GetCdPlaylist |
126 | dd syscall_putarea_backgr ; 25-Put Area to background |
126 | dd syscall_putarea_backgr ; 25-Put Area to background |
127 | dd sys_getsetup ; 26-GetMidiBase,GetKeymap,GetShiftKeymap,. |
127 | dd sys_getsetup ; 26-GetMidiBase,GetKeymap,GetShiftKeymap,. |
128 | dd undefined_syscall ; 27-reserved |
128 | dd undefined_syscall ; 27-reserved |
129 | dd undefined_syscall ; 28-reserved |
129 | dd undefined_syscall ; 28-reserved |
130 | dd sys_date ; 29-GetDate |
130 | dd sys_date ; 29-GetDate |
131 | dd sys_current_directory ; 30-Get/SetCurrentDirectory |
131 | dd sys_current_directory ; 30-Get/SetCurrentDirectory |
132 | dd undefined_syscall ; 31-reserved |
132 | dd undefined_syscall ; 31-reserved |
133 | dd undefined_syscall ; 32-reserved |
133 | dd undefined_syscall ; 32-reserved |
134 | dd undefined_syscall ; 33-reserved |
134 | dd undefined_syscall ; 33-reserved |
135 | dd syscall_getpixel_WinMap ; 34-GetPixel WinMap |
135 | dd syscall_getpixel_WinMap ; 34-GetPixel WinMap |
136 | dd syscall_getpixel ; 35-GetPixel |
136 | dd syscall_getpixel ; 35-GetPixel |
137 | dd syscall_getarea ; 36-GetArea |
137 | dd syscall_getarea ; 36-GetArea |
138 | dd readmousepos ; 37-GetMousePosition_ScreenRelative,. |
138 | dd readmousepos ; 37-GetMousePosition_ScreenRelative,. |
139 | dd syscall_drawline ; 38-DrawLine |
139 | dd syscall_drawline ; 38-DrawLine |
140 | dd sys_getbackground ; 39-GetBackgroundSize,ReadBgrData,. |
140 | dd sys_getbackground ; 39-GetBackgroundSize,ReadBgrData,. |
141 | dd set_app_param ; 40-WantEvents |
141 | dd set_app_param ; 40-WantEvents |
142 | dd undefined_syscall ; 41- deprecated GetIrqOwner |
142 | dd undefined_syscall ; 41- deprecated GetIrqOwner |
143 | dd undefined_syscall ; 42- deprecated ReadIrqData |
143 | dd undefined_syscall ; 42- deprecated ReadIrqData |
144 | dd sys_outport ; 43-SendDeviceData |
144 | dd sys_outport ; 43-SendDeviceData |
145 | dd undefined_syscall ; 44- deprecated ProgramIrqs |
145 | dd undefined_syscall ; 44- deprecated ProgramIrqs |
146 | dd undefined_syscall ; 45- deprecated ReserveIrq and FreeIrq |
146 | dd undefined_syscall ; 45- deprecated ReserveIrq and FreeIrq |
147 | dd syscall_reserveportarea ; 46-ReservePortArea and FreePortArea |
147 | dd syscall_reserveportarea ; 46-ReservePortArea and FreePortArea |
148 | dd display_number ; 47-WriteNum |
148 | dd display_number ; 47-WriteNum |
149 | dd syscall_display_settings ; 48-SetRedrawType and SetButtonType |
149 | dd syscall_display_settings ; 48-SetRedrawType and SetButtonType |
150 | dd sys_apm ; 49-Advanced Power Management (APM) |
150 | dd sys_apm ; 49-Advanced Power Management (APM) |
151 | dd syscall_set_window_shape ; 50-Window shape & scale |
151 | dd syscall_set_window_shape ; 50-Window shape & scale |
152 | dd syscall_threads ; 51-Threads |
152 | dd syscall_threads ; 51-Threads |
153 | dd undefined_syscall ; 52- deprecated Stack driver status |
153 | dd undefined_syscall ; 52- deprecated Stack driver status |
154 | dd undefined_syscall ; 53- deprecated Socket interface |
154 | dd undefined_syscall ; 53- deprecated Socket interface |
155 | dd sys_clipboard ; 54-Custom clipboard |
155 | dd sys_clipboard ; 54-Custom clipboard |
156 | dd sound_interface ; 55-Sound interface |
156 | dd sound_interface ; 55-Sound interface |
157 | dd undefined_syscall ; 56-reserved |
157 | dd undefined_syscall ; 56-reserved |
158 | dd sys_pcibios ; 57-PCI BIOS32 |
158 | dd sys_pcibios ; 57-PCI BIOS32 |
159 | dd undefined_syscall ; 58-deprecated Common file system interface |
159 | dd undefined_syscall ; 58-deprecated Common file system interface |
160 | dd undefined_syscall ; 59-reserved |
160 | dd undefined_syscall ; 59-reserved |
161 | dd sys_IPC ; 60-Inter Process Communication |
161 | dd sys_IPC ; 60-Inter Process Communication |
162 | dd sys_gs ; 61-Direct graphics access |
162 | dd sys_gs ; 61-Direct graphics access |
163 | dd pci_api ; 62-PCI functions |
163 | dd pci_api ; 62-PCI functions |
164 | dd sys_msg_board ; 63-System message board |
164 | dd sys_msg_board ; 63-System message board |
165 | dd sys_resize_app_memory ; 64-Resize application memory usage |
165 | dd sys_resize_app_memory ; 64-Resize application memory usage |
166 | dd sys_putimage_palette ; 65-PutImagePalette |
166 | dd sys_putimage_palette ; 65-PutImagePalette |
167 | dd sys_process_def ; 66-Process definitions - keyboard |
167 | dd sys_process_def ; 66-Process definitions - keyboard |
168 | dd syscall_move_window ; 67-Window move or resize |
168 | dd syscall_move_window ; 67-Window move or resize |
169 | dd f68 ; 68-Some internal services |
169 | dd f68 ; 68-Some internal services |
170 | dd sys_debug_services ; 69-Debug |
170 | dd sys_debug_services ; 69-Debug |
171 | dd file_system_lfn ; 70-Common file system interface, version 2 |
171 | dd file_system_lfn ; 70-Common file system interface, version 2 |
172 | dd syscall_window_settings ; 71-Window settings |
172 | dd syscall_window_settings ; 71-Window settings |
173 | dd sys_sendwindowmsg ; 72-Send window message |
173 | dd sys_sendwindowmsg ; 72-Send window message |
174 | dd blit_32 ; 73-blitter; |
174 | dd blit_32 ; 73-blitter; |
175 | dd sys_network ; 74-reserved for new stack |
175 | dd sys_network ; 74-reserved for new stack |
176 | dd sys_socket ; 75-reserved for new stack |
176 | dd sys_socket ; 75-reserved for new stack |
177 | dd sys_protocols ; 76-reserved for new stack |
177 | dd sys_protocols ; 76-reserved for new stack |
178 | dd sys_posix ; posix support |
178 | dd sys_posix ; posix support |
179 | dd undefined_syscall ; 78-free |
179 | dd undefined_syscall ; 78-free |
180 | dd undefined_syscall ; 79-free |
180 | dd undefined_syscall ; 79-free |
181 | dd fileSystemUnicode ; 80-File system interface for different encodings |
181 | dd fileSystemUnicode ; 80-File system interface for different encodings |
- | 182 | dd sys_array ; 81-Array |
|
182 | 183 | ||
183 | times 255 - ( ($-servetable2) /4 ) dd undefined_syscall |
184 | times 255 - ( ($-servetable2) /4 ) dd undefined_syscall |
184 | dd sys_end ; -1-end application |
185 | dd sys_end ; -1-end application |
185 | 186 | ||
186 | endg |
187 | endg |