;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; ;; ;; Copyright (C) KolibriOS team 2004-2007. All rights reserved. ;; ;; Distributed under terms of the GNU General Public License ;; ;; ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; $Revision$ keymap: db '6',27 db '1234567890-=',8,9 db 'qwertyuiop[]',13 db '~asdfghjkl;',39,96,0,'\zxcvbnm,./',0,'45 ' db '@234567890123',180,178,184,'6',176,'7' db 179,'8',181,177,183,185,182 db 'AB<D',255,'FGHIJKLMNOPQRSTUVWXYZ' db 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' db 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' db 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' keymap_shift: db '6',27 db '!@#$%^&*()_+',8,9 db 'QWERTYUIOP{}',13 db '~ASDFGHJKL:"~',0,'|ZXCVBNM<>?',0,'45 ' db '@234567890123',180,178,184,'6',176,'7' db 179,'8',181,177,183,185,182 db 'AB>D',255,'FGHIJKLMNOPQRSTUVWXYZ' db 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' db 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' db 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' keymap_alt: db ' ',27 db ' @ $ {[]}\ ',8,9 db ' ',13 db ' ',0,' ',0,'4',0,' ' db ' ',180,178,184,'6',176,'7' db 179,'8',181,177,183,185,182 db 'ABCD',255,'FGHIJKLMNOPQRSTUVWXYZ' db 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' db 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' db 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' boot_memdetect db 'Determining amount of memory',0 boot_fonts db 'Fonts loaded',0 boot_tss db 'Setting TSSs',0 boot_cpuid db 'Reading CPUIDs',0 boot_devices db 'Detecting devices',0 boot_timer db 'Setting timer',0 boot_irqs db 'Reprogramming IRQs',0 boot_setmouse db 'Setting mouse',0 boot_windefs db 'Setting window defaults',0 boot_bgr db 'Calculating background',0 boot_resirqports db 'Reserving IRQs & ports',0 boot_setrports db 'Setting addresses for IRQs',0 boot_setostask db 'Setting OS task',0 boot_allirqs db 'Unmasking all IRQs',0 boot_tsc db 'Reading TSC',0 boot_cpufreq db 'CPU frequency is ',' ',' MHz',0 boot_pal_ega db 'Setting EGA/CGA 320x200 palette',0 boot_pal_vga db 'Setting VGA 640x480 palette',0 boot_failed db 'Failed to start first app',0 boot_mtrr db 'Setting MTRR',0 ;if preboot_blogesc ; boot_tasking db 'All set - press ESC to start',0 ;end if ;new_process_loading db 'K : New Process - loading',13,10,0 ;new_process_running db 'K : New Process - done',13,10,0 start_not_enough_memory db 'K : New Process - not enough memory',13,10,0 msg_unresolved db 'unresolved ',0 msg_module db 'in module ',0 msg_version db 'incompatible driver version',13,10,0 msg_www db 'please visit www.kolibrios.org',13,10,0 msg_CR db 13,10,0 aSis db 'SIS',0 intel_str db "GenuineIntel",0 AMD_str db "AuthenticAMD",0 ;szSound db 'SOUND',0 ;szInfinity db 'INFINITY',0 szHwMouse db 'ATI2D',0 szPS2MDriver db 'PS2MOUSE',0 szCOM_MDriver db 'COM_MOUSE',0 szUSB db 'USB',0 szAtiHW db '/rd/1/drivers/ati2d.drv',0 szSTART db 'START',0 szEXPORTS db 'EXPORTS',0 sz_EXPORTS db '_EXPORTS',0 szIMPORTS db 'IMPORTS',0 read_firstapp db '/sys/' firstapp db '@DESKTOP',0 char db '/rd/1/FONTS/CHAR.MT',0 char2 db '/rd/1/FONTS/CHAR2.MT',0 bootpath db '/KOLIBRI ' bootpath2 db 0 vmode db '/sys/drivers/VMODE.MDR',0 vrr_m db 'VRR_M',0 kernel_file db 'KERNEL MNT' align 4 shmem_list: .bk dd shmem_list .fd dd shmem_list ; supported videomodes mode_1280_1024_32: dw 1280,1024,32,60 mode_1280_1024_24: dw 1280,1024,24,60 mode_1024_768_32: dw 1024,768,32,60 mode_1024_768_24: dw 1024,768,24,60 mode_800_600_32: dw 800,600,32,60 mode_800_600_24: dw 800,600,24,60 mode_640_480_32: dw 640,480,32,60 mode_640_480_24: dw 640,480,24,60 mode_640_480_16: dw 640,480,16,60 mode_320_240_8: dw 320,240,8,60 ; mike.dld { db 0 dd servetable-0x10000 draw_line dd __sys_draw_line disable_mouse dd __sys_disable_mouse draw_pointer dd __sys_draw_pointer ;//mike.dld, 2006-08-02 [ ;drawbar dd __sys_drawbar drawbar dd __sys_drawbar.forced ;//mike.dld, 2006-08-02 ] putpixel dd __sys_putpixel ; } mike.dld align 4 keyboard dd 1 syslang dd 1 boot_y dd 10 pci_bios_entry dd 0 dw sel_pci_code if __DEBUG__ eq 1 include_debug_strings end if IncludeIGlobals align 16 _gdts: dw (gdte - _gdts -1) dd _gdts dw 0 tss_l: dw TSS_SIZE-1 dw tss and 0xFFFF db (tss shr 16) and 0xFF db 10001001b dw (tss shr 16) and 0xFF00 ; Attention! Do not change the order of the first four selectors. They are used in Fast System Call ; must be : os_code, os_data, app_code, app_data, .... os_code_l: ;0x10 dw 0xffff dw 0x0000 db 0x00 dw 11011111b *256 +10011010b db 0x00 os_stacK_l: ;0x18 dw 0xffff dw 0x0000 db 0x00 dw 11011111b *256 +10010010b db 0x00 app_code_l: ;0x20 dw 0xFFFF dw 0 db 0 db cpl3 dw G32+D32+0xF; app_data_l: ;0x28 dw 0xFFFF dw 0 db 0 db drw3 dw G32+D32+0xF; srv_code_l: ;0x30 dw 0xFFFF dw 0 db 0 db cpl1 dw G32+D32+0xF; srv_stack_l: ;0x38 dw 0xFFFF dw 0 db 0 db drw1 dw G32+D32+0xF; ; ------------- PCI BIOS ------------------ pci_code_32: dw 0 ;lim 0-15 dw 0 ;base 0-15 db 0 ;base 16-23 db cpl0 ;type db D32 ;lim 16-19+props db 0 ;base 24-31 pci_data_32: dw 0 ;lim 0-15 dw 0 ;base 0-15 db 0 ;base 16-23 db dpl0 ;type db D32 ;lim 16-19+props db 0 ;base 24-31 ; --------------- APM --------------------- apm_code_32: dw 0x0f ; limit 64kb db 0, 0, 0 dw 11010000b *256 +10011010b db 0x00 apm_code_16: dw 0x0f db 0, 0, 0 dw 10010000b *256 +10011010b db 0x00 apm_data_16: dw 0x0f db 0, 0, 0 dw 10010000b *256 +10010010b db 0x00 ; ----------------------------------------- graph_data_l: dw 0x7ff dw 0x0000 db 0x00 dw 11010000b *256 +11110010b db 0x00 code_16_l: dw 0xFFFF dw 0 db 1 db cpl0 dw 0 endofcode: gdte: section '.bss' data writeable align 4096 align 4096 SLOT_BASE: rb 64*1024 DRIVE_DATA: rb 64*1024 RESERVED_PORTS: rb 64*1024 FLOPPY_BUFF: rb 16*1024 BUTTON_INFO: rb 16*1024 BgrAuxTable: rb 32*1024 skin_data: rb 32*1024 IDE_DMA: rb 32*1024 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; window_data: rb 8192 CURRENT_TASK: _current_task: rb 8192 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; draw_data: rb 4096 CDDataBuf: rb 4096 cur_saved_data rb 4096 _sys_pdbr rd 1024 fpu_data: rb 512 WIN_STACK: rb 0x400 WIN_POS: rb 0x800 idts rq 0x42 ; device irq owners irq_owner rd 16 ; process id ; on irq read ports irq00read rd 16 irq01read rd 16 irq02read rd 16 irq03read rd 16 irq04read rd 16 irq05read rd 16 irq06read rd 16 irq07read rd 16 irq08read rd 16 irq09read rd 16 irq10read rd 16 irq11read rd 16 irq12read rd 16 irq13read rd 16 irq14read rd 16 irq15read rd 16 irq_tab rd 16 FONT_I rb 2304 ;16*144 FONT_II rb 2560 ;16*160 RAMDISK_FAT: rb 2856*2 +16 ;16*357 FLOPPY_FAT: rb 2856*2 +16 _z_core rd 52 mem_block_map rb 512 event_map rb 64 mem_block_list rd 64 large_block_list rd 31 mem_block_mask rd 2 large_block_mask rd 1 _boot_mbi rd 1 _mem_amount rd 1 _rd_base rd 1 _rd_fat rd 1 ;RAMDISK + 512 _rd_fat_end rd 1 ;RAMDISK + 512 + 4278 _rd_root rd 1 ;RAMDISK + 512*18 + 512 _rd_root_end rd 1 ;RAMDISK + 512*33 heap_mutex rd 1 heap_size rd 1 heap_free rd 1 heap_blocks rd 1 free_blocks rd 1 mst MEM_STATE page_start rd 1 page_end rd 1 events rd 1 event_start rd 1 event_end rd 1 event_uid rd 1 sys_page_map rd 1 srv.fd rd 1 srv.bk rd 1 _HwCursorCreate: create_cursor rd 1 _SelectHwCursor: select_hw_cursor rd 1 _SetHwCursor: set_hw_cursor rd 1 _HwCursorRestore: hw_restore rd 1 def_cursor rd 1 current_cursor rd 1 hw_cursor rd 1 cur_saved_base rd 1 cur.lock rd 1 ;1 - lock update, 2- hide cur.left rd 1 ;cursor clip box cur.top rd 1 cur.right rd 1 cur.bottom rd 1 cur.w rd 1 cur.h rd 1 ipc_tmp rd 1 ipc_pdir rd 1 ipc_ptab rd 1 proc_mem_map rd 1 proc_mem_pdir rd 1 proc_mem_tab rd 1 tmp_task_pdir rd 1 tmp_task_ptab rd 1 default_io_map rd 1 stall_mcs rd 1 _current_slot: current_slot rd 1 _display_data rd 1 _current_thread rd 1 _k_reenter rd 1 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; scr_mode rd 1 LFBAddress rd 1 LFBSize rd 1 ;8Mb hardcoded ScreenBPP rd 1 BytesPerScanLine rd 1 put_pixel rd 1 get_pixel rd 1 _screen_width rd 1 _screen_height rd 1 Screen_Max_X rd 1 Screen_Max_Y rd 1 btn_addr rd 1 redraw_background rd 1 BgrDrawMode rd 1 BgrDataWidth rd 1 BgrDataHeight rd 1 MOUSE_VISIBLE rd 1 WIN_TEMP_XY rd 1 MOUSE_X rw 1 MOUSE_Y rw 1 mouse_scroll_v rd 1 mouse_scroll_h rd 1 BTN_COUNT rd 1 BTN_BUFF rd 1 KEY_COUNT rd 1 KEY_BUFF rb 128 btn_down rd 1 x_under rd 1 y_under rd 1 dont_switch rd 1 sys_shutdown rd 1 bank_rw rd 1 CPU_FREQ rd 1 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; status hd1_status rd 1 ; 0 - free : other - pid application_table_status rd 1 ; 0 - free : other - pid ; device addresses mididp rd 1 midisp rd 1 cdbase rd 1 cdid rd 1 hdbase rd 1 ; for boot 0x1f0 hdid rd 1 hdpos rd 1 ; for boot 0x1 fat32part rd 1 ; for boot 0x1 cdpos rd 1 ;CPUID information cpu_vendor rd 3 cpu_sign rd 1 cpu_info rd 1 cpu_caps rd 4 pg_data PG_DATA heap_test rd 1 buttontype rd 1 windowtypechanged rd 1 hd_entries rd 1 ;unused ? 0xfe10 ;* start code - Mario79 mouse_active rd 1 mouse_pause rd 1 MouseTickCounter rd 1 ;* end code - Mario79 img_background rd 1 mem_BACKGROUND rd 1 wraw_bacground_select rb 1 cache_ide0: cache_ide0_pointer rd 1 cache_ide0_size rd 1 ; not use cache_ide0_data_pointer rd 1 cache_ide0_system_data_size rd 1 ; not use cache_ide0_appl_data_size rd 1 ; not use cache_ide0_system_data rd 1 cache_ide0_appl_data rd 1 cache_ide0_system_sad_size rd 1 cache_ide0_appl_sad_size rd 1 cache_ide0_search_start rd 1 cache_ide0_appl_search_start rd 1 cache_ide1: cache_ide1_pointer rd 1 cache_ide1_size rd 1 ; not use cache_ide1_data_pointer rd 1 cache_ide1_system_data_size rd 1 ; not use cache_ide1_appl_data_size rd 1 ; not use cache_ide1_system_data rd 1 cache_ide1_appl_data rd 1 cache_ide1_system_sad_size rd 1 cache_ide1_appl_sad_size rd 1 cache_ide1_search_start rd 1 cache_ide1_appl_search_start rd 1 cache_ide2: cache_ide2_pointer rd 1 cache_ide2_size rd 1 ; not use cache_ide2_data_pointer rd 1 cache_ide2_system_data_size rd 1 ; not use cache_ide2_appl_data_size rd 1 ; not use cache_ide2_system_data rd 1 cache_ide2_appl_data rd 1 cache_ide2_system_sad_size rd 1 cache_ide2_appl_sad_size rd 1 cache_ide2_search_start rd 1 cache_ide2_appl_search_start rd 1 cache_ide3: cache_ide3_pointer rd 1 cache_ide3_size rd 1 ; not use cache_ide3_data_pointer rd 1 cache_ide3_system_data_size rd 1 ; not use cache_ide3_appl_data_size rd 1 ; not use cache_ide3_system_data rd 1 cache_ide3_appl_data rd 1 cache_ide3_system_sad_size rd 1 cache_ide3_appl_sad_size rd 1 cache_ide3_search_start rd 1 cache_ide3_appl_search_start rd 1 debug_step_pointer rd 1 hdd_appl_data rb 1 ; 0 = system cache, 1 - application cache cd_appl_data rb 1 ; 0 = system cache, 1 - application cache align 4 lba_read_enabled rd 1 ; 0 = disabled , 1 = enabled pci_access_enabled rd 1 ; 0 = disabled , 1 = enabled timer_ticks_enable rb 1 ; for cd driver align 4 NumBiosDisks rd 1 BiosDisksData rb 200h BiosDiskCaches rb 80h*(cache_ide1-cache_ide0) BiosDiskPartitions rd 80h IncludeUGlobals