CTAOS v5
This commit is contained in:
		
										
											Binary file not shown.
										
									
								
							| @@ -1,10 +1,13 @@ | ||||
| ;***** memory.inc **************************************************** | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Enable A20 address line                                   * | ||||
| ;*         =======================                                   * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
|  | ||||
|  | ||||
| ;******************************************** | ||||
| ;	Enable A20 address line | ||||
| ; | ||||
| ;	OS Development Series | ||||
| ;******************************************** | ||||
| %ifndef __A20_INC_CTA000__ | ||||
| %define __A20_INC_CTA000__ | ||||
|  | ||||
| bits	16							; real mode 16 bit code | ||||
|  | ||||
| @@ -53,3 +56,5 @@ a20wait2: | ||||
|         test    al,1 | ||||
|         jz      a20wait2 | ||||
|         ret | ||||
|  | ||||
| %endif | ||||
| @@ -1,39 +1,38 @@ | ||||
| ;***** bootinfo.inc ************************************************** | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Multiboot information structure                           * | ||||
| ;*         ===============================                           * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
|  | ||||
| ;******************************************************* | ||||
| ; | ||||
| ;	bootinfo.inc | ||||
| ;		multiboot information structure | ||||
| ; | ||||
| ;	OS Development Series | ||||
| ;******************************************************* | ||||
|  | ||||
| %ifndef __BOOTINFO_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %define __BOOTINFO_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %ifndef __BOOTINFO_INC_CTA001__ | ||||
| %define __BOOTINFO_INC_CTA001__ | ||||
|  | ||||
| struc multiboot_info | ||||
| 	.flags				resd	1 | ||||
| 	.memoryLo			resd	1 | ||||
| 	.memoryHi			resd	1 | ||||
| 	.bootDevice			resd	1 | ||||
| 	.cmdLine			resd	1 | ||||
| 	.mods_count			resd	1 | ||||
| 	.mods_addr			resd	1 | ||||
| 	.syms0				resd	1 | ||||
| 	.syms1				resd	1 | ||||
| 	.syms2				resd	1 | ||||
| 	.mmap_length		resd	1 | ||||
| 	.mmap_addr			resd	1 | ||||
| 	.drives_length		resd	1 | ||||
| 	.drives_addr		resd	1 | ||||
| 	.config_table		resd	1 | ||||
| 	.bootloader_name	resd	1 | ||||
| 	.apm_table			resd	1 | ||||
| 	.vbe_control_info	resd	1 | ||||
| 	.vbe_mode_info		resd	1 | ||||
| 	.vbe_mode			resw	1 | ||||
| 	.vbe_interface_seg	resw	1 | ||||
| 	.vbe_interface_off	resw	1 | ||||
| 	.vbe_interface_len	resw	1 | ||||
|       .flags                  resd 1 | ||||
|       .memoryLo               resd 1 | ||||
|       .memoryHi               resd 1 | ||||
|       .bootDevice             resd 1 | ||||
|       .cmdLine                resd 1 | ||||
|       .mods_count             resd 1 | ||||
|       .mods_addr              resd 1 | ||||
|       .syms0                  resd 1 | ||||
|       .syms1                  resd 1 | ||||
|       .syms2                  resd 1 | ||||
|       .mmap_length            resd 1 | ||||
|       .mmap_addr              resd 1 | ||||
|       .drives_length          resd 1 | ||||
|       .drives_addr            resd 1 | ||||
|       .config_table           resd 1 | ||||
|       .bootloader_name        resd 1 | ||||
|       .apm_table              resd 1 | ||||
|       .vbe_control_info       resd 1 | ||||
|       .vbe_mode_info          resd 1 | ||||
|       .vbe_mode               resw 1 | ||||
|       .vbe_interface_seg      resw 1 | ||||
|       .vbe_interface_off      resw 1 | ||||
|       .vbe_interface_len      resw 1 | ||||
| endstruc | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -1,9 +1,16 @@ | ||||
| ;***** common.inc **************************************************** | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Common definitions, variables                             * | ||||
| ;*         =============================                             * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
|  | ||||
| %ifndef _COMMON_INC_INCLUDED | ||||
| %define _COMMON_INC_INCLUDED | ||||
| %ifndef _COMMON_INC_CTA002__ | ||||
| %define _COMMON_INC_CTA002__ | ||||
|  | ||||
| ; where the kernel is to be loaded to in protected mode | ||||
| %define IMAGE_PMODE_BASE 0x100000 | ||||
| %define IMAGE_PMODE_BASE 0xC0000000 | ||||
|  | ||||
| ; where the kernel is to be loaded to in real mode | ||||
| %define IMAGE_RMODE_BASE 0x3000 | ||||
|   | ||||
| @@ -1,14 +1,13 @@ | ||||
| ;***** FAT12.inc ***************************************************** | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Fat12 filesystem for 3.5" floppies                        * | ||||
| ;*         ==================================                        * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
|  | ||||
| ;******************************************************* | ||||
| ; | ||||
| ;	Fat12.inc | ||||
| ;		FAT12 filesystem for 3-1/2 floppies | ||||
| ; | ||||
| ;	OS Development Series | ||||
| ;******************************************************* | ||||
|  | ||||
| %ifndef __FAT12_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %define __FAT12_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %ifndef __FAT12_INC_CTA003__ | ||||
| %define __FAT12_INC_CTA003__ | ||||
|  | ||||
| bits	16 | ||||
|  | ||||
|   | ||||
| @@ -1,18 +1,17 @@ | ||||
| ;***** floppy16.inc ************************************************** | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Floppy drive interface routines                           * | ||||
| ;*         ===============================                           * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
|  | ||||
| ;******************************************************* | ||||
| ; | ||||
| ;	Floppy16.inc | ||||
| ;		Floppy drive interface routines | ||||
| ; | ||||
| ;	OS Development Series | ||||
| ;******************************************************* | ||||
|  | ||||
| %ifndef __FLOPPY16_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %define __FLOPPY16_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %ifndef __FLOPPY16_INC_CTA004__ | ||||
| %define __FLOPPY16_INC_CTA004__ | ||||
|  | ||||
| bits	16 | ||||
|  | ||||
| bpbOEM			db "My OS   " | ||||
| bpbOEM			db "CTA OS  " | ||||
| bpbBytesPerSector:  	DW 512 | ||||
| bpbSectorsPerCluster: 	DB 1 | ||||
| bpbReservedSectors: 	DW 1 | ||||
| @@ -29,7 +28,7 @@ bsDriveNumber: 	        DB 0 | ||||
| bsUnused: 		DB 0 | ||||
| bsExtBootSignature: 	DB 0x29 | ||||
| bsSerialNumber:	        DD 0xa0a1a2a3 | ||||
| bsVolumeLabel: 	        DB "MOS FLOPPY " | ||||
| bsVolumeLabel: 	        DB "CTA OS     " | ||||
| bsFileSystem: 	        DB "FAT12   " | ||||
|  | ||||
| datasector  dw 0x0000 | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| ;***** gdt.inc ******************************************************* | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Global Descriptor Table routines                          * | ||||
| ;*         =====================                                     * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
|  | ||||
|  | ||||
| ;************************************************* | ||||
| ;	Gdt.inc | ||||
| ;		-GDT Routines | ||||
| ; | ||||
| ;	OS Development Series | ||||
| ;************************************************* | ||||
|  | ||||
| %ifndef __GDT_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %define __GDT_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %ifndef __GDT_INC_CTA005__ | ||||
| %define __GDT_INC_CTA005__ | ||||
|  | ||||
| bits	16 | ||||
|  | ||||
|   | ||||
							
								
								
									
										98
									
								
								SysBoot/stage2/getdata.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								SysBoot/stage2/getdata.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,98 @@ | ||||
|  | ||||
| gatherinfo: | ||||
|       pusha | ||||
|       push es | ||||
|       xor         eax, eax | ||||
|       mov         ebx, eax | ||||
|       mov         ecx, eax | ||||
|       mov         edx, eax | ||||
| ;Boot device | ||||
| 	mov         dword [multiboot_info_bootDevice], 0      ; drive 0 | ||||
|  | ||||
| ;Detect current video mode | ||||
|       mov         ah, 0Fh | ||||
|       int         10h | ||||
|       mov         byte [multiboot_info_video_mode], al | ||||
|       mov         byte [multiboot_info_video_columns], ah | ||||
|       mov         byte [multiboot_info_video_page], bh | ||||
|        | ||||
| ;Get VESA information | ||||
|       xor         eax, eax | ||||
|       xor         ebx, ebx | ||||
|       xor         edx, edx | ||||
|       mov         dword [TemporaryStorage], vbeControllerInfo | ||||
|       mov         ax, word [TemporaryStorage] | ||||
|       mov         dx, word [TemporaryStorage+2] | ||||
|       shl         ax, 1 | ||||
|       mov         es, ax | ||||
|       mov         di, dx | ||||
|       mov         ax, 0x4f00 | ||||
|       int         10h | ||||
|       cmp         ax, 0x004F | ||||
|        | ||||
|             ; not correct | ||||
|       je          vesa_00_ok | ||||
|       mov         dword [multiboot_info_vbe_control_info], 0x0    ; failure | ||||
|       jmp vesa_00_done | ||||
|        | ||||
|             ; correct | ||||
|    vesa_00_ok: | ||||
|       mov         dword [multiboot_info_vbe_control_info], vbeControllerInfo ; success   | ||||
|        | ||||
|    vesa_00_done: | ||||
| ;Write VBE 2.0+ Interface pointers to 0 | ||||
|       mov         word [multiboot_info_vbe_interface_seg], 0 | ||||
|       mov         word [multiboot_info_vbe_interface_off], 0 | ||||
|       mov         word [multiboot_info_vbe_interface_len], 0 | ||||
|        | ||||
| ;Get VESA Current mode | ||||
|       mov         ax, 4f03h | ||||
|       int         10h | ||||
|       cmp         ax, 004fh | ||||
|       je vesa_01_ok | ||||
|        | ||||
|       ; not ok: | ||||
|       mov         word [multiboot_info_vbe_mode], 0 | ||||
|       jmp vesa_01_done | ||||
|        | ||||
|    vesa_01_ok: | ||||
|       mov         word [multiboot_info_vbe_mode], bx | ||||
|        | ||||
|    vesa_01_done: | ||||
|  | ||||
| ;Get some info about current VESA mode | ||||
|       xor         eax, eax | ||||
|       mov         ebx, eax | ||||
|       mov         edx, eax | ||||
|  | ||||
|       mov eax, vbeControllerInfo | ||||
|       push        eax | ||||
|       and         eax, 0fh | ||||
|       mov         dx, ax | ||||
|       pop         eax | ||||
|  | ||||
|       shr         eax, 4 | ||||
|  | ||||
|       mov         es, ax | ||||
|       mov         di, dx | ||||
|  | ||||
|        | ||||
|       mov         ax, 4f01h | ||||
|       mov         cx, [multiboot_info_vbe_mode] | ||||
|       int         10h | ||||
|        | ||||
|       cmp         ax, 004fh | ||||
|       je vesa_02_ok | ||||
|        | ||||
|       ; not ok: | ||||
|       mov         word [multiboot_info_vbe_mode_info], 0 | ||||
|       jmp vesa_02_done | ||||
|        | ||||
|    vesa_02_ok: | ||||
|       mov         word [multiboot_info_vbe_mode_info], vbeModeInfo | ||||
|        | ||||
|    vesa_02_done: | ||||
|       pop es | ||||
|       popa | ||||
|       ret | ||||
|        | ||||
| @@ -1,13 +1,13 @@ | ||||
| ;***** memory.inc **************************************************** | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Basic memory routines                                     * | ||||
| ;*         =====================                                     * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
|  | ||||
| ;************************************************* | ||||
| ;	Memory.inc | ||||
| ;		-Basic memory routines | ||||
| ; | ||||
| ;	OS Development Series | ||||
| ;************************************************* | ||||
|  | ||||
| %ifndef __MEMORY_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %define __MEMORY_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %ifndef __MEMORY_INC_CTA006__ | ||||
| %define __MEMORY_INC_CTA006__ | ||||
|  | ||||
| bits 16 | ||||
|  | ||||
| @@ -29,43 +29,50 @@ endstruc | ||||
| ;--------------------------------------------- | ||||
|  | ||||
| BiosGetMemoryMap: | ||||
| 	pushad | ||||
|  | ||||
| 	xor		ebx, ebx | ||||
| 	xor		bp, bp									; number of entries stored here | ||||
| 	mov		edx, 'PAMS'								; 'SMAP' | ||||
| 	xor		bp, bp | ||||
| 	mov		edx, 0x0534D4150		; Place "SMAP" into edx | ||||
| 	mov		eax, 0xe820 | ||||
| 	mov		ecx, 24									; memory map entry struct is 24 bytes | ||||
| 	int		0x15									; get first entry | ||||
| 	jc		.error	 | ||||
| 	cmp		eax, 'PAMS'								; bios returns SMAP in eax | ||||
| 	jne		.error | ||||
| 	test	ebx, ebx								; if ebx=0 then list is one entry long; bail out | ||||
| 	je		.error | ||||
| 	jmp		.start | ||||
| .next_entry: | ||||
| 	mov		edx, 'PAMS'								; some bios's trash this register | ||||
| 	mov		ecx, 24									; entry is 24 bytes | ||||
| 	mov		eax, 0xe820 | ||||
| 	int		0x15									; get next entry | ||||
| .start: | ||||
| 	jcxz	.skip_entry								; if actual returned bytes is 0, skip entry | ||||
| 	mov		[es:di + 20], dword 1	; force a valid ACPI 3.X entry | ||||
| 	mov		ecx, 24 | ||||
| 	int		0x15 | ||||
| 	jc		short .failed			; carry set on first call means "unsupported function" | ||||
| 	mov		edx, 0x0534D4150		; Some BIOSes apparently trash this register? | ||||
| 	cmp		eax, edx				; on success, eax must have been reset to "SMAP" | ||||
| 	jne		short .failed | ||||
| 	test	ebx, ebx				; ebx = 0 implies list is only 1 entry long (worthless) | ||||
| 	je		short .failed | ||||
| 	jmp		short .jmpin | ||||
| .e820lp: | ||||
| 	mov		eax, 0xe820				; eax, ecx get trashed on every int 0x15 call | ||||
| 	mov		[es:di + 20], dword 1	; force a valid ACPI 3.X entry | ||||
| 	mov		ecx, 24					; ask for 24 bytes again | ||||
| 	int		0x15 | ||||
| 	jc		short .e820f			; carry set means "end of list already reached" | ||||
| 	mov		edx, 0x0534D4150		; repair potentially trashed register | ||||
| .jmpin: | ||||
| 	jcxz	.skipent				; skip any 0 length entries | ||||
| 	cmp		cl, 20					; got a 24 byte ACPI 3.X response? | ||||
| 	jbe		short .notext | ||||
| 	test	byte [es:di + 20], 1	; if so: is the "ignore this data" bit clear? | ||||
| 	je		short .skipent | ||||
| .notext: | ||||
| 	mov		ecx, [es:di + MemoryMapEntry.length]	; get length (low dword) | ||||
| 	test	ecx, ecx								; if length is 0 skip it | ||||
| 	jne		short .good_entry | ||||
| 	mov		ecx, [es:di + MemoryMapEntry.length + 4]; get length (upper dword) | ||||
| 	jecxz	.skip_entry								; if length is 0 skip it | ||||
| .good_entry: | ||||
| 	inc		bp										; increment entry count | ||||
| 	add		di, 24									; point di to next entry in buffer | ||||
| .skip_entry: | ||||
| 	cmp		ebx, 0									; if ebx return is 0, list is done | ||||
| 	jne		.next_entry								; get next entry | ||||
| 	jmp		.done | ||||
| .error: | ||||
| 	stc | ||||
| .done: | ||||
| 	popad | ||||
| 	mov		ecx, [es:di + 8]		; get lower dword of memory region length | ||||
| 	test	ecx, ecx				; is the qword == 0? | ||||
| 	jne		short .goodent | ||||
| 	mov		ecx, [es:di + 12]		; get upper dword of memory region length | ||||
| 	jecxz	.skipent				; if length qword is 0, skip entry | ||||
| .goodent: | ||||
| 	inc		bp						; got a good entry: ++count, move to next storage spot | ||||
| 	add		di, 24 | ||||
| .skipent: | ||||
| 	test	ebx, ebx				; if ebx resets to 0, list is complete | ||||
| 	jne		short .e820lp | ||||
| .e820f: | ||||
| 	ret								; bp=entry count | ||||
| .failed: | ||||
| 	stc								; "function unsupported" error exit | ||||
| 	ret | ||||
|  | ||||
| ;--------------------------------------------- | ||||
| @@ -75,21 +82,17 @@ BiosGetMemoryMap: | ||||
| ;	ret\ bx=0 and ax= -1 on error | ||||
| ;--------------------------------------------- | ||||
|  | ||||
| BiosGetMemorySize64MB_32Bit: | ||||
| BiosGetMemorySize64MB_32bit: | ||||
| 	push	ecx | ||||
| 	push	edx | ||||
| 	xor		ecx, ecx | ||||
| 	xor		edx, edx | ||||
| 	mov		ax, 0xe881 | ||||
| 	int		0x15	 | ||||
| 	mov		eax, 0xe881 | ||||
| 	int		0x15 | ||||
| 	jc		.error | ||||
| 	cmp		ah, 0x86		;unsupported function | ||||
| 	je		.error | ||||
| 	cmp		ah, 0x80		;invalid command | ||||
| 	je		.error | ||||
| 	jcxz	.use_ax			;bios may have stored it in ax,bx or cx,dx. test if cx is 0 | ||||
| 	mov		ax, cx			;its not, so it should contain mem size; store it | ||||
| 	mov		bx, dx | ||||
| 	jcxz	.use_ax				;bios may have stored it in ax,bx or cx,dx. test if cx is 0 | ||||
| 	mov		eax, ecx			;its not, so it should contain mem size; store it | ||||
| 	mov		ebx, edx | ||||
|  | ||||
| .use_ax: | ||||
| 	pop		edx				;mem size is in ax and bx already, return it | ||||
| @@ -102,7 +105,7 @@ BiosGetMemorySize64MB_32Bit: | ||||
| 	pop		edx | ||||
| 	pop		ecx | ||||
| 	ret | ||||
| 	 | ||||
|  | ||||
| ;--------------------------------------------- | ||||
| ;	Get memory size for >64M configuations | ||||
| ;	ret\ ax=KB between 1MB and 16MB | ||||
| @@ -132,8 +135,6 @@ BiosGetMemorySize64MB: | ||||
| 	ret | ||||
|  | ||||
| .error: | ||||
|       mov         si, msgNotSupported | ||||
|       call Puts16 | ||||
| 	mov		ax, -1 | ||||
| 	mov		bx, 0 | ||||
| 	pop		edx | ||||
| @@ -170,6 +171,4 @@ BiosGetExtendedMemorySize: | ||||
| 	ret | ||||
|  | ||||
|  | ||||
| msgNotSupported db 0x0A, 0x0D, "BiosGetMemorySize64MB: function not supported.",0x0A, 0x0D, 0x00 | ||||
|  | ||||
| %endif | ||||
|   | ||||
							
								
								
									
										83
									
								
								SysBoot/stage2/paging.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								SysBoot/stage2/paging.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | ||||
| ;***** paging.inc **************************************************** | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Basic paging for bootloader                               * | ||||
| ;*         ===========================                               * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
|  | ||||
| %ifndef __PAGING_INC_CTA007__ | ||||
| %define __PAGING_INC_CTA007__ | ||||
|  | ||||
| [bits 32] | ||||
|  | ||||
| %define PAGE_DIR              0x9C000     ; page directory table | ||||
| %define PAGE_TABLE_0          0x9D000     ; 0th page table. Address must be 4KB aligned | ||||
| %define PAGE_TABLE_768        0x9E000     ; 768th page table. Address must be 4KB aligned | ||||
| %define PAGE_TABLE_ENTRIES    1024        ; each page table has 1024 entries | ||||
| %define PRIV                  3           ; attributes (page is present;page is writable; supervisor mode) | ||||
|  | ||||
|  | ||||
| ;**************************************** | ||||
| ;      Enable Paging | ||||
| ;**************************************** | ||||
|  | ||||
| EnablePaging: | ||||
|       pusha                                                       ; save stack frame | ||||
|  | ||||
|       ;------------------------------------------ | ||||
|       ;      idenitity map 1st page table (4MB) | ||||
|       ;------------------------------------------ | ||||
|  | ||||
|       mov            eax, PAGE_TABLE_0                            ; first page table | ||||
|       mov            ebx, 0x0 | PRIV                              ; starting physical address of page | ||||
|       mov            ecx, PAGE_TABLE_ENTRIES                      ; for every page in table... | ||||
| .loop: | ||||
|       mov            dword [eax], ebx                             ; write the entry | ||||
|       add            eax, 4                                       ; go to next page entry in table (Each entry is 4 bytes) | ||||
|       add            ebx, 4096                                    ; go to next page address (Each page is 4Kb) | ||||
|       loop      .loop                                             ; go to next entry | ||||
|  | ||||
|       ;------------------------------------------ | ||||
|       ;      set up the entries in the directory table | ||||
|       ;------------------------------------------ | ||||
|  | ||||
|       mov            eax, PAGE_TABLE_0 | PRIV                     ; 1st table is directory entry 0 | ||||
|       mov            dword [PAGE_DIR], eax | ||||
|  | ||||
|       mov            eax, PAGE_TABLE_768 | PRIV                   ; 768th entry in directory table | ||||
|       mov            dword [PAGE_DIR+(768*4)], eax | ||||
|  | ||||
|       ;------------------------------------------ | ||||
|       ;      install directory table | ||||
|       ;------------------------------------------ | ||||
|  | ||||
|       mov            eax, PAGE_DIR | ||||
|       mov            cr3, eax | ||||
|  | ||||
|       ;------------------------------------------ | ||||
|       ;      enable paging | ||||
|       ;------------------------------------------ | ||||
|  | ||||
|       mov            eax, cr0 | ||||
|       or             eax, 0x80000000 | ||||
|       mov            cr0, eax | ||||
|  | ||||
|       ;------------------------------------------ | ||||
|       ;      map the 768th table to physical addr 1MB | ||||
|       ;      the 768th table starts the 3gb virtual address | ||||
|       ;------------------------------------------ | ||||
|   | ||||
|       mov            eax, PAGE_TABLE_768                          ; first page table | ||||
|       mov            ebx, 0x100000 | PRIV                         ; starting physical address of page | ||||
|       mov            ecx, PAGE_TABLE_ENTRIES                      ; for every page in table... | ||||
| .loop2: | ||||
|       mov            dword [eax], ebx                             ; write the entry | ||||
|       add            eax, 4                                       ; go to next page entry in table (Each entry is 4 bytes) | ||||
|       add            ebx, 4096                                    ; go to next page address (Each page is 4Kb) | ||||
|       loop      .loop2                                            ; go to next entry | ||||
|  | ||||
|       popa | ||||
|       ret | ||||
|  | ||||
| %endif | ||||
| @@ -1,12 +1,10 @@ | ||||
|  | ||||
| ;******************************************************* | ||||
| ; | ||||
| ;	Stage2.asm | ||||
| ;		Stage2 Bootloader | ||||
| ; | ||||
| ;	OS Development Series | ||||
| ;******************************************************* | ||||
|  | ||||
| ;***** stage2.asm **************************************************** | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Stage 2 Bootloader                                        * | ||||
| ;*         ==================                                        * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
| bits	16 | ||||
|  | ||||
| org 0x500 | ||||
| @@ -24,6 +22,7 @@ jmp	main				; go to start | ||||
| %include "common.inc" | ||||
| ;%include "bootinfo.inc" | ||||
| %include "memory.inc" | ||||
| %include "getdata.inc" | ||||
|  | ||||
| ;******************************************************* | ||||
| ;	Data Section | ||||
| @@ -32,28 +31,51 @@ jmp	main				; go to start | ||||
| msgFailure db 0x0D, 0x0A, "FATAL ERROR: Kernel file KERNEL.CTA missing or corrupt. Press Any Key to Reboot.", 0x0D, 0x0A, 0x0A, 0x00 | ||||
|  | ||||
| boot_info: | ||||
| 	   multiboot_info_flags 			dd 0 | ||||
| 	   multiboot_info_memoryLo 			dd 0 | ||||
| 	   multiboot_info_memoryHi 			dd 0 | ||||
| 	   multiboot_info_bootDevice 		dd 0 | ||||
| 	   multiboot_info_cmdLine			dd 0 | ||||
| 	   multiboot_info_mods_count 		dd 0 | ||||
| 	   multiboot_info_mods_addr 		dd 0 | ||||
| 	   multiboot_info_syms0 			dd 0 | ||||
| 	   multiboot_info_syms1 			dd 0 | ||||
| 	   multiboot_info_syms2 			dd 0 | ||||
| 	   multiboot_info_mmap_length 		dd 0 | ||||
| 	   multiboot_info_mmap_addr 		dd 0 | ||||
| 	   multiboot_info_drives_length 	dd 0 | ||||
| 	   multiboot_info_drives_addr 		dd 0 | ||||
| 	   multiboot_info_config_table 		dd 0 | ||||
| 	   multiboot_info_bootloader_name 	dd 0 | ||||
| 	   multiboot_info_apm_table 		dd 0 | ||||
| 	   multiboot_info_vbe_control_info 	dd 0 | ||||
| 	   multiboot_info_vbe_mode_info 	dw 0 | ||||
| 	   multiboot_info_vbe_interface_seg dw 0 | ||||
| 	   multiboot_info_vbe_interface_off dw 0 | ||||
| 	   multiboot_info_vbe_interface_len dw 0 | ||||
|             ; Memory | ||||
|       multiboot_info_memoryLo             dd 0 | ||||
|       multiboot_info_memoryHi             dd 0 | ||||
|             ; Boot device | ||||
|       multiboot_info_bootDevice           dd 0 | ||||
|             ; Pointer to a char[] string. (not implemented) | ||||
|       multiboot_info_cmdLine              dd 0 | ||||
|             ; Other modules loaded by bootloader. (not implemented | ||||
|       multiboot_info_mods_count           dd 0 | ||||
|       multiboot_info_mods_addr            dd 0 | ||||
|             ; Pointer to memory map | ||||
|       multiboot_info_mmap_length          dd 0 | ||||
|       multiboot_info_mmap_addr            dd 0 | ||||
|             ; TODO: | ||||
|       multiboot_info_drives_length        dd 0 | ||||
|       multiboot_info_drives_addr          dd 0 | ||||
|             ; BIOS ROM config table. TODO: | ||||
|       multiboot_info_config_table         dd 0 | ||||
|             ; CTA bootloader name | ||||
|       multiboot_info_bootloader_name      db "CTA", 0 | ||||
|             ; TODO: | ||||
|       multiboot_info_apm_table            dd 0 | ||||
|             ; Returns VGA current video mode info | ||||
|       multiboot_info_video_mode           db 0 | ||||
|       multiboot_info_video_columns        db 0 | ||||
|       multiboot_info_video_page           db 0 | ||||
|             ; Returns VESA information | ||||
|       multiboot_info_vbe_control_info     dd 0 | ||||
|       multiboot_info_vbe_mode_info        dd 0 | ||||
|       multiboot_info_vbe_mode             dw 0 | ||||
|       multiboot_info_vbe_interface_seg    dw 0 | ||||
|       multiboot_info_vbe_interface_off    dw 0 | ||||
|       multiboot_info_vbe_interface_len    dw 0 | ||||
|  | ||||
|  | ||||
| vbeControllerInfo: | ||||
|       vbeControllerInfo_signature         dd 0 ; "VESA", taken as 4 bytes | ||||
|       vbeControllerInfo_version           dw 0 ; 0x0300 for VBE 3.0 | ||||
|       vbeControllerInfo_oemString         dd 0 ; isa vbeFarPtr, taken as 2 shorts | ||||
|       vbeControllerInfo_capabilities      dd 0 ; taken as 4 bytes | ||||
|       vbeControllerInfo_videomodes        dd 0 ; isa vbeFarPtr, taken as 2 shorts | ||||
|       vbeControllerInfo_totalMemory       dw 0 ; as # of 64k blocks | ||||
|  | ||||
|  | ||||
| TemporaryStorage                          dd 0 ; temporary storage | ||||
|  | ||||
| main: | ||||
|  | ||||
| @@ -70,34 +92,48 @@ main: | ||||
| 	mov		sp, 0xFFFF | ||||
| 	sti	                   ; enable interrupts | ||||
|  | ||||
| 	mov     [multiboot_info_bootDevice], dl | ||||
|  | ||||
| 	call	_EnableA20 | ||||
| 	call	InstallGDT | ||||
| 	sti | ||||
|  | ||||
|  | ||||
| 	;-------------------------------; | ||||
| 	;   Fill in the boot structure ; | ||||
| 	;-------------------------------; | ||||
| ; Memory Size | ||||
| 	xor		eax, eax | ||||
| 	xor		ebx, ebx | ||||
| 	call	BiosGetMemorySize64MB | ||||
|  | ||||
| 	mov		word [multiboot_info_memoryHi], bx | ||||
| 	mov		word [multiboot_info_memoryLo], ax | ||||
| 		 | ||||
|       push		eax | ||||
| 	mov		eax, 64 | ||||
| 	mul		ebx | ||||
| 	mov		ecx, eax | ||||
| 	pop		eax | ||||
| 	add		eax, ecx | ||||
| 	add		eax, 1024		; the routine doesnt add the KB between 0-1MB; add it | ||||
|  | ||||
| 	mov		dword [multiboot_info_memoryHi], 0         | ||||
| 	mov		dword [multiboot_info_memoryLo], eax | ||||
|  | ||||
| ;Memory map | ||||
| 	mov		eax, 0x0 | ||||
| 	mov		ds, ax | ||||
| 	mov		di, 0x1000 | ||||
| 	call	BiosGetMemoryMap | ||||
| 	mov         dword [multiboot_info_mmap_addr], 0x1000 | ||||
| 	 | ||||
| 	mov         dword [multiboot_info_mmap_addr], 0x1000  ; address | ||||
| 	xor         eax, eax | ||||
| 	mov         ax, bp | ||||
| 	mov         dword [multiboot_info_mmap_length], eax | ||||
| 	mov         dword [multiboot_info_mmap_length], eax   ; length	 | ||||
| 	 | ||||
|       call gatherinfo | ||||
|        | ||||
|  | ||||
| 	call	LoadRoot | ||||
|    	mov    	ebx, 0 | ||||
|    	mov		ebp, IMAGE_RMODE_BASE | ||||
|    	mov 	esi, ImageName | ||||
| 	call	LoadFile		; load our file | ||||
| 	call        LoadRoot | ||||
|    	mov         ebx, 0 | ||||
|    	mov         ebp, IMAGE_RMODE_BASE | ||||
|    	mov         esi, ImageName | ||||
| 	call        LoadFile		; load our file | ||||
|    	mov   	dword [ImageSize], ecx | ||||
| 	cmp		ax, 0 | ||||
| 	je		EnterStage3 | ||||
| @@ -129,6 +165,8 @@ EnterStage3: | ||||
|  | ||||
| bits 32 | ||||
|  | ||||
| %include "paging.inc" | ||||
|  | ||||
| BadImage db "FATAL ERROR: Kernel file KERNEL.CTA missing or corrupt. Press Any Key to Reboot.", 0 | ||||
|  | ||||
| Stage3: | ||||
| @@ -143,6 +181,7 @@ Stage3: | ||||
| 	mov	es, ax | ||||
| 	mov	esp, 90000h		; stack begins from 90000h | ||||
|  | ||||
|       call EnablePaging | ||||
|  | ||||
| CopyImage: | ||||
|   	 mov	eax, dword [ImageSize] | ||||
| @@ -156,7 +195,7 @@ CopyImage: | ||||
|    	 mov	ecx, eax | ||||
|    	 rep	movsd                   ; copy image to its protected mode address | ||||
|  | ||||
| 	 mov		eax, 0x2badb002			; multiboot specs say eax should be this | ||||
| 	 mov		eax, 0xC0DEcC7A			; cta bootloader specific | ||||
| 	 mov		ebx, 0 | ||||
| 	 | ||||
| ;edx=8 | ||||
| @@ -169,4 +208,56 @@ CopyImage: | ||||
|  | ||||
|     cli | ||||
| 	hlt | ||||
| 	 | ||||
|  | ||||
|  | ||||
| vbeModeInfo: | ||||
|   vbeModeInfo_attributes      dw 0 | ||||
|   vbeModeInfo_winA            db 0 | ||||
|   vbeModeInfo_winB            db 0 | ||||
|   vbeModeInfo_granularity     dw 0 | ||||
|   vbeModeInfo_winsize         dw 0 | ||||
|   vbeModeInfo_segmentA        dw 0 | ||||
|   vbeModeInfo_segmentB        dw 0 | ||||
|   vbeModeInfo_realFctPtr      dd 0 | ||||
|   vbeModeInfo_pitc            dw 0        ; // bytes per scanline | ||||
|   vbeModeInfo_Xres            dw 0 | ||||
|   vbeModeInfo_Yres            dw 0 | ||||
|   vbeModeInfo_Wchar           db 0 | ||||
|   vbeModeInfo_Ychar           db 0 | ||||
|   vbeModeInfo_planes          db 0 | ||||
|   vbeModeInfo_bpp             db 0 | ||||
|   vbeModeInfo_banks           db 0 | ||||
|   vbeModeInfo_memory_model    db 0 | ||||
|   vbeModeInfo_bank_size       db 0 | ||||
|   vbeModeInfo_image_pages     db 0 | ||||
|   vbeModeInfo_reserved0       db 0 | ||||
|    | ||||
|   ; VBE v1.2+ | ||||
|   vbeModeInfo_red_mask        db 0 | ||||
|   vbeModeInfo_red_position    db 0 | ||||
|   vbeModeInfo_green_mask      db 0 | ||||
|   vbeModeInfo_green_position  db 0 | ||||
|   vbeModeInfo_blue_mask       db 0 | ||||
|   vbeModeInfo_blue_position   db 0 | ||||
|   vbeModeInfo_rsv_mask        db 0 | ||||
|   vbeModeInfo_rsv_position    db 0 | ||||
|   vbeModeInfo_directcolor_attrib    db 0 | ||||
|    | ||||
|   ; VBE v2.0+ | ||||
|   vbeModeInfo_physbase        dd 0 | ||||
|   vbeModeInfo_start_offscreen_mem   dd 0 | ||||
|   vbeModeInfo_size_offscreen_mem    dw 0 | ||||
|    | ||||
|   ; VBE v3.0+ | ||||
|   vbeModeInfo_bytes_per_scanline    dw 0 | ||||
|   vbeModeInfo_number_images_banked  db 0 | ||||
|   vbeModeInfo_number_images_linear  db 0 | ||||
|   vbeModeInfo_linear_red_mask       db 0 | ||||
|   vbeModeInfo_linear_red_pos        db 0 | ||||
|   vbeModeInfo_linear_green_mask     db 0 | ||||
|   vbeModeInfo_linear_green_pos      db 0 | ||||
|   vbeModeInfo_linear_blue_mask      db 0 | ||||
|   vbeModeInfo_linear_blue_pos       db 0 | ||||
|   vbeModeInfo_linear_res_mask       db 0 | ||||
|   vbeModeInfo_linear_res_pos        db 0 | ||||
|   vbeModeInfo_max_pixel_clock       dd 0 | ||||
| @@ -1,13 +1,14 @@ | ||||
| ;***** stdio.inc ***************************************************** | ||||
| ;* (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
| ;*                                                                   * | ||||
| ;*         Standard Input/Output routines                            * | ||||
| ;*         ==============================                            * | ||||
| ;*                                                                   * | ||||
| ;************************************************************ cta os */ | ||||
|  | ||||
| ;************************************************* | ||||
| ;	stdio.inc | ||||
| ;		-Input/Output routines | ||||
| ; | ||||
| ;	OS Development Series | ||||
| ;************************************************* | ||||
|  | ||||
| %ifndef __STDIO_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %define __STDIO_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
| %ifndef __STDIO_INC_CTA008__ | ||||
| %define __STDIO_INC_CTA008__ | ||||
|  | ||||
|  | ||||
| ;========================================================== | ||||
| @@ -82,15 +83,15 @@ PutINT: | ||||
| ;	 32 Bit Protected Mode Routines | ||||
| ;========================================================== | ||||
|  | ||||
| bits 32 | ||||
|  ;bits 32 | ||||
|  | ||||
| %define		VIDMEM	0xB8000			; video memory | ||||
| %define		COLS	80			; width and height of screen | ||||
| %define		LINES	25 | ||||
| %define		CHAR_ATTRIB 14			; character attribute (White text on black background) | ||||
| ;%define		VIDMEM	0xB8000			; video memory | ||||
| ;%define		COLS	80			; width and height of screen | ||||
| ;%define		LINES	25 | ||||
| ;%define		CHAR_ATTRIB 14			; character attribute (White text on black background) | ||||
|  | ||||
| _CurX db 0					; current x/y location | ||||
| _CurY db 0 | ||||
| ;_CurX db 0					; current x/y location | ||||
| ;_CurY db 0 | ||||
|  | ||||
| ;**************************************************; | ||||
| ;	Putch32 () | ||||
| @@ -98,56 +99,56 @@ _CurY db 0 | ||||
| ;	BL => Character to print | ||||
| ;**************************************************; | ||||
|  | ||||
| Putch32: | ||||
|  | ||||
| 	pusha | ||||
| 	mov	edi, VIDMEM | ||||
|  | ||||
| 	xor	eax, eax		; clear eax | ||||
|  | ||||
| 	; y * screen width | ||||
|  | ||||
| 	mov	ecx, COLS*2		; Mode 7 has 2 bytes per char, so its COLS*2 bytes per line | ||||
| 	mov	al, byte [_CurY]	; get y pos | ||||
| 	mul	ecx			; multiply y*COLS | ||||
| 	push	eax			; save eax--the multiplication | ||||
| ;Putch32: | ||||
| ; | ||||
| ;	pusha | ||||
| ;	mov	edi, VIDMEM | ||||
| ; | ||||
| ;	xor	eax, eax		; clear eax | ||||
| ; | ||||
| ;	; y * screen width | ||||
| ; | ||||
| ;	mov	ecx, COLS*2		; Mode 7 has 2 bytes per char, so its COLS*2 bytes per line | ||||
| ;	mov	al, byte [_CurY]	; get y pos | ||||
| ;	mul	ecx			; multiply y*COLS | ||||
| ;	push	eax			; save eax--the multiplication | ||||
|  | ||||
| 	; now add _CurX * 2 | ||||
|  | ||||
| 	mov	al, byte [_CurX]	; multiply _CurX by 2 because it is 2 bytes per char | ||||
| 	mov	cl, 2 | ||||
| 	mul	cl | ||||
| 	pop	ecx			; pop y*COLS result | ||||
| 	add	eax, ecx | ||||
| ;	mov	al, byte [_CurX]	; multiply _CurX by 2 because it is 2 bytes per char | ||||
| ;	mov	cl, 2 | ||||
| ;	mul	cl | ||||
| ;	pop	ecx			; pop y*COLS result | ||||
| ;	add	eax, ecx | ||||
|  | ||||
| 	; add the position to draw to the base of vid memory | ||||
|  | ||||
| 	xor	ecx, ecx | ||||
| 	add	edi, eax		; add it to the base address | ||||
|  | ||||
| ;	xor	ecx, ecx | ||||
| ;	add	edi, eax		; add it to the base address | ||||
| ; | ||||
| 	; watch for new line | ||||
|  | ||||
| 	cmp	bl, 0x0A		; is it a newline character? | ||||
| 	je	.Row			; yep--go to next row | ||||
|  | ||||
| ;	cmp	bl, 0x0A		; is it a newline character? | ||||
| ;	je	.Row			; yep--go to next row | ||||
| ; | ||||
| 	; print the character | ||||
|  | ||||
| 	mov	dl, bl			; Get character | ||||
| 	mov	dh, CHAR_ATTRIB		; the character attribute | ||||
| 	mov	word [edi], dx		; write to video display | ||||
| ;	mov	dl, bl			; Get character | ||||
| ;	mov	dh, CHAR_ATTRIB		; the character attribute | ||||
| ;	mov	word [edi], dx		; write to video display | ||||
| ; | ||||
| ;	; go to next location | ||||
|  | ||||
| 	; go to next location | ||||
| ;	inc	byte [_CurX]		; go to next character | ||||
| ;	jmp	.done			; nope, bail out | ||||
|  | ||||
| 	inc	byte [_CurX]		; go to next character | ||||
| 	jmp	.done			; nope, bail out | ||||
| ;.Row: | ||||
| ;	mov	byte [_CurX], 0		; go back to col 0 | ||||
| ;	inc	byte [_CurY]		; go to next row | ||||
|  | ||||
| .Row: | ||||
| 	mov	byte [_CurX], 0		; go back to col 0 | ||||
| 	inc	byte [_CurY]		; go to next row | ||||
|  | ||||
| .done: | ||||
| 	popa | ||||
| 	ret | ||||
| ;.done: | ||||
| ;	popa | ||||
| ;	ret | ||||
|  | ||||
| ;**************************************************; | ||||
| ;	Puts32 () | ||||
| @@ -155,47 +156,47 @@ Putch32: | ||||
| ;	parm\ EBX = address of string to print | ||||
| ;**************************************************; | ||||
|  | ||||
| Puts32: | ||||
| ;Puts32: | ||||
|  | ||||
| 	pusha | ||||
| 	push	ebx			; copy the string address | ||||
| 	pop	edi | ||||
| ;	pusha | ||||
| ;	push	ebx			; copy the string address | ||||
| ;	pop	edi | ||||
|  | ||||
| .loop: | ||||
| ;.loop: | ||||
|  | ||||
| 	;-------------------------------; | ||||
| 	;   Get character               ; | ||||
| 	;-------------------------------; | ||||
|  | ||||
| 	mov	bl, byte [edi]		; get next character | ||||
| 	cmp	bl, 0			; is it 0 (Null terminator)? | ||||
| 	je	.done			; yep-bail out | ||||
| ;	mov	bl, byte [edi]		; get next character | ||||
| ;	cmp	bl, 0			; is it 0 (Null terminator)? | ||||
| ;	je	.done			; yep-bail out | ||||
|  | ||||
| 	;-------------------------------; | ||||
| 	;   Print the character         ; | ||||
| 	;-------------------------------; | ||||
|  | ||||
| 	call	Putch32			; Nope-print it out | ||||
| ;	call	Putch32			; Nope-print it out | ||||
|  | ||||
| 	;-------------------------------; | ||||
| 	;   Go to next character        ; | ||||
| 	;-------------------------------; | ||||
|  | ||||
| 	inc	edi			; go to next character | ||||
| 	jmp	.loop | ||||
| ;	inc	edi			; go to next character | ||||
| ;	jmp	.loop | ||||
|  | ||||
| .done: | ||||
| ;.done: | ||||
|  | ||||
| 	;-------------------------------; | ||||
| 	;   Update hardware cursor      ; | ||||
| 	;-------------------------------; | ||||
|  | ||||
| 	mov	bh, byte [_CurY]	; get current position | ||||
| 	mov	bl, byte [_CurX] | ||||
| 	call	MovCur			; update cursor | ||||
| ;	mov	bh, byte [_CurY]	; get current position | ||||
| ;	mov	bl, byte [_CurX] | ||||
| ;	call	MovCur			; update cursor | ||||
|  | ||||
| 	popa				; restore registers, and return | ||||
| 	ret | ||||
| ;	popa				; restore registers, and return | ||||
| ;	ret | ||||
|  | ||||
| ;**************************************************; | ||||
| ;	MoveCur () | ||||
| @@ -206,74 +207,74 @@ Puts32: | ||||
|        | ||||
|  | ||||
|  | ||||
| bits 32 | ||||
| ;bits 32 | ||||
|  | ||||
| MovCur: | ||||
|  | ||||
| 	pusha | ||||
| ;MovCur: | ||||
|  | ||||
| ;	pusha | ||||
| ; | ||||
| 	;-------------------------------; | ||||
| 	;   Get current position        ; | ||||
| 	;-------------------------------; | ||||
|  | ||||
| 	; location = _CurX + _CurY * COLS | ||||
|  | ||||
| 	xor	eax, eax | ||||
| 	mov	ecx, COLS | ||||
| 	mov	al, bh			; get y pos | ||||
| 	mul	ecx			; multiply y*COLS | ||||
| 	add	al, bl			; Now add x | ||||
| 	mov	ebx, eax | ||||
|  | ||||
| ;	xor	eax, eax | ||||
| ;	mov	ecx, COLS | ||||
| ;	mov	al, bh			; get y pos | ||||
| ;	mul	ecx			; multiply y*COLS | ||||
| ;	add	al, bl			; Now add x | ||||
| ;	mov	ebx, eax | ||||
| ; | ||||
| 	;--------------------------------------; | ||||
| 	;   Set low byte index to VGA register ; | ||||
| 	;--------------------------------------; | ||||
|  | ||||
| 	mov	al, 0x0f | ||||
| 	mov	dx, 0x03D4 | ||||
| 	out	dx, al | ||||
|  | ||||
| 	mov	al, bl | ||||
| 	mov	dx, 0x03D5 | ||||
| 	out	dx, al			; low byte | ||||
| ;	mov	al, 0x0f | ||||
| ;	mov	dx, 0x03D4 | ||||
| ;	out	dx, al | ||||
| ; | ||||
| ;	mov	al, bl | ||||
| ;	mov	dx, 0x03D5 | ||||
| ;	out	dx, al			; low byte | ||||
|  | ||||
| 	;---------------------------------------; | ||||
| 	;   Set high byte index to VGA register ; | ||||
| 	;---------------------------------------; | ||||
|  | ||||
| 	xor	eax, eax | ||||
| ;	xor	eax, eax | ||||
|  | ||||
| 	mov	al, 0x0e | ||||
| 	mov	dx, 0x03D4 | ||||
| 	out	dx, al | ||||
| ;	mov	al, 0x0e | ||||
| ;	mov	dx, 0x03D4 | ||||
| ;	out	dx, al | ||||
|  | ||||
| 	mov	al, bh | ||||
| 	mov	dx, 0x03D5 | ||||
| 	out	dx, al			; high byte | ||||
| ;	mov	al, bh | ||||
| ;	mov	dx, 0x03D5 | ||||
| ;	out	dx, al			; high byte | ||||
|  | ||||
| 	popa | ||||
| 	ret | ||||
| ;	popa | ||||
| ;	ret | ||||
|  | ||||
| ;**************************************************; | ||||
| ;	ClrScr32 () | ||||
| ;		- Clears screen | ||||
| ;**************************************************; | ||||
|  | ||||
| bits 32 | ||||
|  | ||||
| ClrScr32: | ||||
|  | ||||
| 	pusha | ||||
| 	cld | ||||
| 	mov	edi, VIDMEM | ||||
| 	mov	cx, 2000 | ||||
| 	mov	ah, CHAR_ATTRIB | ||||
| 	mov	al, ' '	 | ||||
| 	rep	stosw | ||||
| 	mov	byte [_CurX], 0 | ||||
| 	mov	byte [_CurY], 0 | ||||
| 	popa | ||||
| 	ret | ||||
| ; | ||||
| ;bits 32 | ||||
| ; | ||||
| ;ClrScr32: | ||||
| ; | ||||
| ;	pusha | ||||
| ;	cld | ||||
| ;	mov	edi, VIDMEM | ||||
| ;	mov	cx, 2000 | ||||
| ;	mov	ah, CHAR_ATTRIB | ||||
| ;	mov	al, ' '	 | ||||
| ;	rep	stosw | ||||
| ;	mov	byte [_CurX], 0 | ||||
| ;	mov	byte [_CurY], 0 | ||||
| ;	popa | ||||
| ;	ret | ||||
|  | ||||
| ;**************************************************; | ||||
| ;	GotoXY () | ||||
| @@ -282,14 +283,14 @@ ClrScr32: | ||||
| ;	parm\	AH=Y position | ||||
| ;**************************************************; | ||||
|  | ||||
| bits 32 | ||||
| ;bits 32 | ||||
|  | ||||
| GotoXY: | ||||
| 	pusha | ||||
| 	mov	[_CurX], al | ||||
| 	mov	[_CurY], ah | ||||
| 	popa | ||||
| 	ret | ||||
| ;GotoXY: | ||||
| ;	pusha | ||||
| ;	mov	[_CurX], al | ||||
| ;	mov	[_CurY], ah | ||||
| ;	popa | ||||
| ;	ret | ||||
|  | ||||
|  | ||||
| %endif ;__STDIO_INC_67343546FDCC56AAB872_INCLUDED__ | ||||
|   | ||||
| @@ -1,92 +1,81 @@ | ||||
| /***** cmos.c ******************************************************** | ||||
|  * (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
|  *                                                                   * | ||||
|  *          CMOS I/O Routines                                        * | ||||
|  *          =================                                        * | ||||
|  *                                                                   * | ||||
|  * ! IMPORTANT NOTE !  Close interrupts before any CMOS operation    * | ||||
|  ************************************************************ cta os */ | ||||
|  | ||||
| #include <system.h> | ||||
| #include <time.h> | ||||
| #include "cmos.h" | ||||
|  | ||||
| volatile byte i86_cmos_data[128]; | ||||
|  | ||||
| void i86_cmos_write () | ||||
| /***************************************************************** | ||||
|  *    !!!!!!!!!!          IMPORTANT NOTE          !!!!!!!!!!     * | ||||
|  *    You should close interrupts before any CMOS operation.     * | ||||
|  *****************************************************************/ | ||||
| inline unsigned char i86_cmos_read (unsigned char address) | ||||
| { | ||||
|       byte i; | ||||
|       for (i = 0; i < 128; i++) { | ||||
|             //asm volatile ("cli"); | ||||
|             outportb(0x70, i); | ||||
|             iowait(); | ||||
|             outportb(0x71, i86_cmos_data[i]); | ||||
|             //asm volatile ("sti"); | ||||
|             } | ||||
|       outportb(0x70, address); iowait(); | ||||
|       return inportb(0x71); | ||||
| } | ||||
|  | ||||
| void i86_cmos_read () | ||||
| inline void i86_cmos_write (unsigned char address, unsigned char val) | ||||
| { | ||||
|       byte i; | ||||
|       for (i = 0; i < 128; i++) { | ||||
|             //asm volatile ("cli"); | ||||
|             outportb(0x70, i); | ||||
|             iowait(); | ||||
|             i86_cmos_data[i] = inportb(0x71); | ||||
|             //asm volatile ("sti"); | ||||
|             } | ||||
|       outportb(0x70, address); iowait(); | ||||
|       outportb(0x71, val); | ||||
| } | ||||
|  | ||||
| void i86_cmos_write_clock (const TIME* time) | ||||
| { | ||||
|       unsigned char BCD = ((i86_cmos_read(0x0b)&4)==0) ? 1 : 0; | ||||
|       unsigned char ampm = ((i86_cmos_read(0x0b)&2)==0) ? 1 : 0; | ||||
|        | ||||
|       i86_cmos_write (0, (BCD) ? (time->second%10) | (time->second/10*16) : time->second);        // Seconds | ||||
|       i86_cmos_write (2, (BCD) ? (time->minute%10) | (time->minute/10*16) : time->minute);        // Minutes | ||||
|  | ||||
|       if (ampm && time->hour > 12)                                                                // Hours | ||||
|             i86_cmos_write (4, (BCD) ? (((time->hour - 12) % 10) | ((time->hour - 12)/10*16) | 0x80) : (time->hour | 0x80) ); | ||||
|        | ||||
|       else if (ampm && time->hour == 0)                                                           // Midnight convention: 12 PM = 00:00 | ||||
|             i86_cmos_write (4, (BCD) ? 0x92 : 0x8C);  | ||||
|        | ||||
|       else i86_cmos_write (4, (BCD) ? (time->hour%10) | (time->hour/10*16) : time->hour);         // 24h / AM | ||||
|  | ||||
|       i86_cmos_write (6, (BCD) ? (time->weekday%10) | (time->weekday/10*16) : time->weekday);     // Weekday | ||||
|       i86_cmos_write (7, (BCD) ? (time->day%10) | (time->day/10*16) : time->day);                 // Day | ||||
|       i86_cmos_write (8, (BCD) ? (time->month%10) | (time->month/10*16) : time->month);           // Month | ||||
|       i86_cmos_write (9, (BCD) ? (time->year%10) | (time->year/10*16) : time->year);              // Year | ||||
|       i86_cmos_write (0x32, (BCD) ? (time->century%10) | (time->century/10*16) : time->century);  // Century | ||||
| } | ||||
|  | ||||
| void i86_cmos_read_clock(TIME* tim) | ||||
| { | ||||
|       i86_cmos_read(); | ||||
|       unsigned char BCD = ((i86_cmos_read(0x0b)&4)==0) ? 1 : 0; | ||||
|       unsigned char am_pm = ((i86_cmos_read(0x0b)&2)==0) ? 1 : 0; | ||||
|        | ||||
|       if ((i86_cmos_data[0x0b]&4)==0) // BCD = true; | ||||
|       { | ||||
|             tim->seconds = (i86_cmos_data[0x00]%16) + 10*(i86_cmos_data[0x00]/16); | ||||
|             tim->minutes = (i86_cmos_data[0x02]%16) + 10*(i86_cmos_data[0x02]/16); | ||||
|             if ((i86_cmos_data[0x0b]&2)==0) { // AM/PM | ||||
|                         if (i86_cmos_data[0x04]&80) { // pm | ||||
|                           tim->hours = ((i86_cmos_data[0x04]-0x80)%16) + 10*((i86_cmos_data[0x04]-0x80)/16); | ||||
|                           tim->am_pm = 1; | ||||
|                         } | ||||
|                         else { // am | ||||
|                           tim->hours = (i86_cmos_data[0x04]%16) + 10*(i86_cmos_data[0x04]/16); | ||||
|                           tim->am_pm = 0; | ||||
|                         } | ||||
|             } | ||||
|             else { // 24 hours | ||||
|                           tim->hours = (i86_cmos_data[0x04]%16) + 10*(i86_cmos_data[0x04]/16); | ||||
|                           if (tim->hours > 12) { | ||||
|                               tim->am_pm = 1; | ||||
|                               tim->hours -= 12; | ||||
|                           } | ||||
|                           else tim->am_pm = 0; | ||||
|             } | ||||
|       tim->second = (BCD) ? (i86_cmos_read(0x00)%16) + 10*(i86_cmos_read(0x00)/16): i86_cmos_read(0x00); | ||||
|       tim->minute = (BCD) ? (i86_cmos_read(0x02)%16) + 10*(i86_cmos_read(0x02)/16): i86_cmos_read(0x02); | ||||
|  | ||||
|             tim->weekday = (i86_cmos_data[0x06]%16) + 10*(i86_cmos_data[0x06]/16); | ||||
|             tim->day = (i86_cmos_data[0x07]%16) + 10*(i86_cmos_data[0x07]/16); | ||||
|             tim->month = (i86_cmos_data[0x08]%16) + 10*(i86_cmos_data[0x08]/16); | ||||
|             tim->year = (i86_cmos_data[0x09]%16) + 10*(i86_cmos_data[0x09]/16); | ||||
|             tim->century = (i86_cmos_data[0x32]%16) + 10*(i86_cmos_data[0x32]/16); | ||||
|       } | ||||
|              | ||||
|       else {//BCD = false; | ||||
|             tim->seconds = i86_cmos_data[0x00]; | ||||
|             tim->minutes = i86_cmos_data[0x02]; | ||||
|             if ((i86_cmos_data[0x0b]&2)==0) { // AM/PM | ||||
|                         if (i86_cmos_data[0x04]&80) { // pm | ||||
|                           tim->hours = i86_cmos_data[0x04]-0x80; | ||||
|                           tim->am_pm = 1; | ||||
|                         } | ||||
|                         else { // am | ||||
|                           tim->hours = i86_cmos_data[0x04]; | ||||
|                           tim->am_pm = 0; | ||||
|                         } | ||||
|             } | ||||
|             else { // 24 hours | ||||
|                           tim->hours = i86_cmos_data[0x02]; | ||||
|                           if (tim->hours > 12) { | ||||
|                               tim->am_pm = 1; | ||||
|                               tim->hours -= 12; | ||||
|                           } | ||||
|                           else tim->am_pm = 0; | ||||
|             } | ||||
|             tim->weekday = i86_cmos_data[0x06]; | ||||
|             tim->day = i86_cmos_data[0x07]; | ||||
|             tim->month = i86_cmos_data[0x08]; | ||||
|             tim->year = i86_cmos_data[0x09]; | ||||
|             tim->century = i86_cmos_data[0x32]; | ||||
|       // Time is PM | ||||
|       if (am_pm && i86_cmos_read(0x04)&80) { | ||||
|             tim->hour = (BCD) ? ((i86_cmos_read(0x04)-0x80)%16) + 10*((i86_cmos_read(0x04)-0x80)/16): i86_cmos_read(0x04)-0x80; | ||||
|             tim->hour += 12; | ||||
|       } | ||||
|       // 24Hour format, or AM | ||||
|       else tim->hour = (BCD) ? (i86_cmos_read(0x04)%16) + 10*(i86_cmos_read(0x04)/16): i86_cmos_read(0x04);      | ||||
|  | ||||
|       tim->weekday = (BCD) ? (i86_cmos_read(0x06)%16) + 10*(i86_cmos_read(0x06)/16): i86_cmos_read(0x06); | ||||
|       tim->day = (BCD) ? (i86_cmos_read(0x07)%16) + 10*(i86_cmos_read(0x07)/16): i86_cmos_read(0x07); | ||||
|       tim->month = (BCD) ? (i86_cmos_read(0x08)%16) + 10*(i86_cmos_read(0x08)/16): i86_cmos_read(0x08); | ||||
|       tim->year = (BCD) ? (i86_cmos_read(0x09)%16) + 10*(i86_cmos_read(0x09)/16): i86_cmos_read(0x09); | ||||
|       tim->century = (BCD) ? (i86_cmos_read(0x32)%16) + 10*(i86_cmos_read(0x32)/16): i86_cmos_read(0x32); | ||||
| } | ||||
|  | ||||
|  | ||||
| unsigned char i86_cmos_read_floppy_drives () | ||||
| { | ||||
|       outportb (0x70, 0x10); | ||||
|       return inportb(0x71); | ||||
| } | ||||
| @@ -1,10 +1,17 @@ | ||||
| /***** cmos.h ******************************************************** | ||||
|  * (c) 2010 CTA Systems Inc. All rights reserved.                    * | ||||
|  *                                                                   * | ||||
|  *          CMOS I/O Routines                                        * | ||||
|  *          =================                                        * | ||||
|  *                                                                   * | ||||
|  * ! IMPORTANT NOTE !  Close interrupts before any CMOS operation    * | ||||
|  ************************************************************ cta os */ | ||||
|  | ||||
| #ifndef __CMOS_H | ||||
| #define __CMOS_H | ||||
|  | ||||
| extern volatile byte i86_cmos_data[128]; | ||||
|  | ||||
| extern void i86_cmos_write (); | ||||
| extern void i86_cmos_read (); | ||||
| extern void i86_cmos_write_clock (const TIME* time); | ||||
| extern void i86_cmos_read_clock (TIME *tim); | ||||
| extern unsigned char i86_cmos_read_floppy_drives (); | ||||
|  | ||||
| #endif | ||||
| @@ -4,8 +4,6 @@ | ||||
| #include "../idt/idt.h" | ||||
| #define cpuid(in, a, b, c, d) __asm__("cpuid": "=a" (a), "=b" (b), "=c" (c), "=d" (d) : "a" (in)); | ||||
|  | ||||
|  | ||||
|  | ||||
| // initializes cpu resources | ||||
| void i86_cpu_initialize() | ||||
| { | ||||
| @@ -21,15 +19,10 @@ void i86_cpu_shutdown() | ||||
|  | ||||
| char* i86_cpu_get_vender() | ||||
| { | ||||
|       static char vender[13]; | ||||
|       dword unused, arr[3]; | ||||
|       int i; | ||||
|       dword unused; | ||||
|       dword static arr[3]; | ||||
|  | ||||
|       cpuid(0, unused, arr[0], arr[2], arr[1]); | ||||
|  | ||||
|       for (i=0; i<12; i++) | ||||
|             vender[i] = (arr[i/4]>>(i%4*8)) && 0xFF; | ||||
|  | ||||
|       vender[12] = 0; | ||||
|       return vender; | ||||
|       return (char*) arr; | ||||
| } | ||||
							
								
								
									
										18
									
								
								SysCore/hal/dma/compile.bat
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								SysCore/hal/dma/compile.bat
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| @echo off | ||||
| rem The name of the loader assembly file (without extension, must be .asm): | ||||
| set loader_name=loader | ||||
|  | ||||
| rem NASM and DJGPP executable paths: | ||||
| set nasm_path=C:\nasm | ||||
| set djgpp_path=C:\DJGPP\bin | ||||
| set objpath=../../objects | ||||
| set incpath=../../include | ||||
|  | ||||
| @echo on | ||||
| %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/dma.o dma.c | ||||
|  | ||||
| @echo off | ||||
| @echo . | ||||
| @echo Done! | ||||
|  | ||||
| @pause | ||||
							
								
								
									
										137
									
								
								SysCore/hal/dma/dma.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								SysCore/hal/dma/dma.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,137 @@ | ||||
| /***** dma.c ********************************************************* | ||||
|  * (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
|  *                                                                   * | ||||
|  *         Direct Memory Access (DMA) Routines                       * | ||||
|  *         ===================================                       * | ||||
|  *                                                                   * | ||||
|  ************************************************************ cta os */ | ||||
|  | ||||
| #include "dma.h" | ||||
| #include <system.h> | ||||
|  | ||||
| enum DMA0_IO { | ||||
|     DMA0_STATUS_REG = 0x08, | ||||
|     DMA0_COMMAND_REG = 0x08, | ||||
|     DMA0_REQUEST_REG = 0x09, | ||||
|     DMA0_CHANMASK_REG = 0x0a, | ||||
|     DMA0_MODE_REG = 0x0b, | ||||
|     DMA0_CLEARBYTE_FLIPFLOP_REG = 0x0c, | ||||
|     DMA0_TEMP_REG = 0x0d, | ||||
|     DMA0_MASTER_CLEAR_REG = 0x0d, | ||||
|     DMA0_CLEAR_MASK_REG = 0x0e, | ||||
|     DMA0_MASK_REG = 0x0f | ||||
| }; | ||||
|  | ||||
| enum DMA1_IO { | ||||
|     DMA1_STATUS_REG = 0xd0, | ||||
|     DMA1_COMMAND_REG = 0xd0, | ||||
|     DMA1_REQUEST_REG = 0xd2, | ||||
|     DMA1_CHANMASK_REG = 0xd4, | ||||
|     DMA1_MODE_REG = 0xd6, | ||||
|     DMA1_CLEARBYTE_FLIPFLOP_REG = 0xd8, | ||||
|     DMA1_INTER_REG = 0xda, | ||||
|     DMA1_UNMASK_ALL_REG = 0xdc, | ||||
|     DMA1_MASK_REG = 0xde | ||||
| }; | ||||
|  | ||||
| void i86_dma_set_address(unsigned short channel, unsigned char low, unsigned char high) | ||||
| { | ||||
|     if (channel > 7) return;   // Ignore if channel > 7 | ||||
|  | ||||
|     // Calculate port | ||||
|     unsigned short port = (channel >= 4) ? 4*(channel - 4) + 0xc0 : 2*channel; | ||||
|  | ||||
|     // Set address | ||||
|     outportb (port, low); | ||||
|     outportb (port, high); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_dma_set_count (unsigned short channel, unsigned char low, unsigned char high) | ||||
| { | ||||
|     if (channel > 7) return;   // Ignore if channel > 7 | ||||
|  | ||||
|     // Calculate port | ||||
|     unsigned short port = (channel >= 4) ?  4*(channel - 4) + 0xc2 | ||||
|                                          :  (2*channel) + 1; | ||||
|  | ||||
|     // Set count | ||||
|     outportb (port, low); | ||||
|     outportb (port, high); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_dma_set_external_page_registers (unsigned char channel, unsigned char val) | ||||
| { | ||||
|     unsigned short port = 0; | ||||
|  | ||||
|     switch (channel) { | ||||
|         case 1: port = 0x83; break; | ||||
|         case 2: port = 0x81; break; | ||||
|         case 3: port = 0x82; break; | ||||
|         // <- nothing should ever write to chan 4 | ||||
|         case 5: port = 0x89; break; | ||||
|         case 6: port = 0x87; break; | ||||
|         case 7: port = 0x88; break; | ||||
|         default: if (channel == 4 || channel > 14) return; | ||||
|     } | ||||
|  | ||||
|     outportb(port, val); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_dma_mask_channel (unsigned char channel) | ||||
| { | ||||
|     if (channel <= 4) outportb (DMA0_CHANMASK_REG, (1<< (channel -1))); | ||||
|     else outportb (DMA1_CHANMASK_REG, (1<< (channel -5))); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_dma_unmask_channel (unsigned char channel) | ||||
| { | ||||
|     if (channel <= 4) outportb (DMA0_CHANMASK_REG, channel); | ||||
|     else outportb (DMA1_CHANMASK_REG, channel); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_dma_unmask_all() | ||||
| { | ||||
|     outportb (DMA1_UNMASK_ALL_REG, 0xff); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_dma_reset_flipflop (unsigned char dma) | ||||
| { | ||||
|     switch (dma) { | ||||
|         case 0: outportb (DMA0_CLEARBYTE_FLIPFLOP_REG, 0xff); | ||||
|         case 1: outportb (DMA1_CLEARBYTE_FLIPFLOP_REG, 0xff); | ||||
|     } | ||||
| } | ||||
|  | ||||
| void i86_dma_reset () | ||||
| { | ||||
|     outportb (DMA0_TEMP_REG, 0xff); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_dma_set_mode(unsigned char channel, unsigned char mode) | ||||
| { | ||||
|     unsigned char dma = (channel < 4) ? 0:1; | ||||
|     unsigned char chan = (dma == 0) ? channel : channel-4; | ||||
|  | ||||
|     i86_dma_mask_channel (channel); | ||||
|     outportb ((channel < 4) ? DMA0_MODE_REG : DMA1_MODE_REG, chan | mode); | ||||
|     i86_dma_unmask_all (); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_dma_set_read (unsigned char channel) | ||||
| { | ||||
|     i86_dma_set_mode (channel, DMA_MODE_READ_TRANSFER | DMA_MODE_TRANSFER_SINGLE); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_dma_set_write (unsigned char channel) | ||||
| { | ||||
|     i86_dma_set_mode (channel, DMA_MODE_WRITE_TRANSFER | DMA_MODE_TRANSFER_SINGLE); | ||||
| } | ||||
							
								
								
									
										42
									
								
								SysCore/hal/dma/dma.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								SysCore/hal/dma/dma.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | ||||
| /***** dma.h ********************************************************* | ||||
|  * (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
|  *                                                                   * | ||||
|  *         Direct Memory Access (DMA) Routines                       * | ||||
|  *         ===================================                       * | ||||
|  *                                                                   * | ||||
|  ************************************************************ cta os */ | ||||
|  | ||||
| #ifndef __DMA__H__ | ||||
| #define __DMA__H__ | ||||
|  | ||||
| enum DMA_MODE_REG_MASK { | ||||
|     DMA_MODE_MASK_SEL = 3, | ||||
|  | ||||
|     DMA_MODE_MASK_TRA = 0xc, | ||||
|     DMA_MODE_SELF_TEST = 0, | ||||
|     DMA_MODE_READ_TRANSFER = 4, | ||||
|     DMA_MODE_WRITE_TRANSFER = 8, | ||||
|  | ||||
|     DMA_MODE_MASK_AUTO = 0x10, | ||||
|     DMA_MODE_MASK_IDEC = 0x20, | ||||
|  | ||||
|     DMA_MODE_MASK = 0xc0, | ||||
|     DMA_MODE_TRANSFER_ON_DEMAND = 0, | ||||
|     DMA_MODE_TRANSFER_SINGLE = 0x40, | ||||
|     DMA_MODE_TRANSFER_BLOCK = 0x80, | ||||
|     DMA_MODE_TRANSFER_CASCADE = 0xC0 | ||||
| }; | ||||
|  | ||||
| extern void i86_dma_set_address(unsigned short channel, unsigned char low, unsigned char high); | ||||
| extern void i86_dma_set_count (unsigned short channel, unsigned char low, unsigned char high); | ||||
| extern void i86_dma_set_external_page_registers (unsigned char channel, unsigned char val); | ||||
| extern void i86_dma_mask_channel (unsigned char channel); | ||||
| extern void i86_dma_unmask_channel (unsigned char channel); | ||||
| extern void i86_dma_unmask_all(); | ||||
| extern void i86_dma_reset_flipflop (unsigned char dma); | ||||
| extern void i86_dma_reset (); | ||||
| extern void i86_dma_set_mode(unsigned char channel, unsigned char mode); | ||||
| extern void i86_dma_set_read (unsigned char channel); | ||||
| extern void i86_dma_set_write (unsigned char channel); | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										18
									
								
								SysCore/hal/floppy/compile.bat
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								SysCore/hal/floppy/compile.bat
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| @echo off | ||||
| rem The name of the loader assembly file (without extension, must be .asm): | ||||
| set loader_name=loader | ||||
|  | ||||
| rem NASM and DJGPP executable paths: | ||||
| set nasm_path=C:\nasm | ||||
| set djgpp_path=C:\DJGPP\bin | ||||
| set objpath=../../objects | ||||
| set incpath=../../include | ||||
|  | ||||
| @echo on | ||||
| %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/floppy.o floppy.c  | ||||
|  | ||||
| @echo off | ||||
| @echo . | ||||
| @echo Done! | ||||
|  | ||||
| @pause | ||||
							
								
								
									
										356
									
								
								SysCore/hal/floppy/floppy.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										356
									
								
								SysCore/hal/floppy/floppy.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,356 @@ | ||||
| /***** floppy.c ****************************************************** | ||||
|  * (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
|  *                                                                   * | ||||
|  *         Floppy Drive I/O Routines                                 * | ||||
|  *         =========================                                 * | ||||
|  *                                                                   * | ||||
|  ************************************************************ cta os */ | ||||
| #include "../irq/irq.h" | ||||
| #include "../dma/dma.h" | ||||
| #include <system.h> | ||||
| #include <conio.h> | ||||
|  | ||||
|  | ||||
| // Used ports: | ||||
| // *********** | ||||
| // Digital Output Register (DOR):         0x3f2 | ||||
| // Main Status Register (MSR):            0x3f4 | ||||
| // Data Register (FIFO):                  0x3f5 | ||||
| // Configuration Control Register (CTRL): 0x3f7 | ||||
|  | ||||
| unsigned char floppy_drives_installed; | ||||
| volatile unsigned char i86_floppy_new_interrupt; | ||||
| struct { | ||||
|      unsigned char type; | ||||
|      unsigned char data_rate; | ||||
|      unsigned char step_rate_time; | ||||
|      unsigned char head_load_time; | ||||
|      unsigned char head_unload_time; | ||||
|      unsigned char sectors_per_track; | ||||
| } fd[2]; | ||||
|  | ||||
|  | ||||
| // Initialize DMA | ||||
| unsigned char i86_floppy_initialize_dma(unsigned char* buffer, unsigned length) | ||||
| { | ||||
|     union { unsigned char byt[4]; // Low[0], Mid[1], Hi[2] | ||||
|             unsigned long l; | ||||
|     } a, c; | ||||
|  | ||||
|     a.l = (unsigned) buffer; | ||||
|     c.l = (unsigned) length-1; | ||||
|  | ||||
|     // Check for buffer issues | ||||
|     if ((a.l >> 24) || (c.l >> 16) || (((a.l & 0xffff)+c.l) >> 16)) return 0; | ||||
|  | ||||
|     i86_dma_reset(); | ||||
|     i86_dma_mask_channel(2);                    // Mask channel 2 | ||||
|     i86_dma_reset_flipflop(1);                  // FlipFlop reset on DMA1 | ||||
|  | ||||
|     i86_dma_set_address(2, a.byt[0], a.byt[1]); // Buffer address | ||||
|     i86_dma_reset_flipflop(1);                  // FlipFlop reset on DMA2 | ||||
|  | ||||
|     i86_dma_set_count(2, c.byt[0], c.byt[1]);   // Set count | ||||
|     i86_dma_set_read(2); | ||||
|     i86_dma_unmask_all(); | ||||
|  | ||||
|     return 1; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| inline void i86_floppy_disable_controller() { | ||||
|     outportb (0x3F2, 0); | ||||
| } | ||||
|  | ||||
| inline void i86_floppy_enable_controller() { | ||||
|     outportb (0x3F2, 4 | 8); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline unsigned char i86_floppy_send_command (unsigned char command) | ||||
| { | ||||
|     int i; | ||||
|     for (i = 0; i < 750; i++) | ||||
|         if (inportb(0x3F4) & 128) { | ||||
|             outportb(0x3F5, command); return 1; | ||||
|         } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline unsigned char i86_floppy_read_data () | ||||
| { | ||||
|     int i; | ||||
|     for (i = 0; i < 750; i++) | ||||
|         if (inportb(0x3F4) & 0x80) | ||||
|             return inportb(0x3F5); | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void i86_floppy_check_int(unsigned* st0, unsigned* cyl) | ||||
| { | ||||
|     i86_floppy_send_command(0x8); | ||||
|     *st0 = i86_floppy_read_data(); | ||||
|     *cyl = i86_floppy_read_data(); | ||||
| } | ||||
|  | ||||
|  | ||||
| extern unsigned i86_pit_get_tick_count(); | ||||
| extern unsigned i86_pit_get_frequency(); | ||||
|  | ||||
|  | ||||
| inline unsigned char i86_floppy_wait() | ||||
| { | ||||
|     unsigned temp = i86_pit_get_tick_count(); | ||||
|     unsigned freq = i86_pit_get_frequency(); | ||||
|      | ||||
|     while (i86_floppy_new_interrupt==0) | ||||
|            if (temp + (3*freq) == i86_pit_get_frequency()) return 0;  // timeout | ||||
|  | ||||
|     i86_floppy_new_interrupt = 0; | ||||
|     return 1; | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_floppy_motor (unsigned char drive, unsigned char on) | ||||
| { | ||||
|     if (drive >= floppy_drives_installed) return; | ||||
|  | ||||
|     // Read DOR register | ||||
|     unsigned char dor = inportb(0x3F2); | ||||
|  | ||||
|     // Un/set selected drive motor | ||||
|     if (on) dor |= drive << 4; | ||||
|     else dor &= ~(drive << 4); | ||||
|  | ||||
|     // Write DOR | ||||
|     outportb (0x3F2, dor); | ||||
|  | ||||
|     // Wait a fifth of a second for motor to turn on | ||||
|     unsigned temp = i86_pit_get_tick_count(); | ||||
|     unsigned freq = i86_pit_get_frequency(); | ||||
|     while (temp + (freq/5) > i86_pit_get_tick_count()); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_floppy_handler(ISR_stack_regs *r) | ||||
| { | ||||
|     i86_floppy_new_interrupt = 1; | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_floppy_drive_data (unsigned char drv, unsigned char dma) | ||||
| { | ||||
|     unsigned data = 0; | ||||
|     if (drv >= floppy_drives_installed) return; | ||||
|  | ||||
|     outportb(0x3F7, fd[drv].data_rate); | ||||
|  | ||||
|     i86_floppy_send_command (0x3); | ||||
|  | ||||
|     data = ((fd[drv].step_rate_time & 0xf) << 4) | (fd[drv].head_unload_time & 0xf); | ||||
|     i86_floppy_send_command (data); | ||||
|  | ||||
|     data = (fd[drv].head_load_time <<1 ) | (dma) ? 1 : 0; | ||||
|     i86_floppy_send_command (data); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void i86_floppy_select(unsigned char drive) | ||||
| { | ||||
|       if (drive >= floppy_drives_installed) return; | ||||
|        | ||||
|       // Send mechanical drive data | ||||
|       i86_floppy_drive_data(drive, 1); | ||||
|  | ||||
|       // Select drive in DOR register | ||||
|       outportb (0x3F2, 4 | 8 | drive); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| unsigned char i86_floppy_calibrate(unsigned drive) | ||||
| { | ||||
|     unsigned st0, cyl; | ||||
|  | ||||
|     if (drive >= floppy_drives_installed) return 0; | ||||
|  | ||||
|     i86_floppy_motor (drive, 1); | ||||
|  | ||||
|     int i; | ||||
|     for (i = 0; i < 15; i++) { | ||||
|         i86_floppy_new_interrupt = 0; | ||||
|         i86_floppy_send_command(0x7); | ||||
|         i86_floppy_send_command(drive); | ||||
|         i86_floppy_wait(); | ||||
|         i86_floppy_check_int(&st0, &cyl); | ||||
|  | ||||
|         if (!cyl) { | ||||
|             i86_floppy_motor(drive, 0); | ||||
|             return 1; | ||||
|         } | ||||
|     } | ||||
|     i86_floppy_motor(drive, 0); | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_floppy_reset() | ||||
| { | ||||
|     unsigned st0, cyl; | ||||
|  | ||||
|     i86_floppy_new_interrupt = 0; | ||||
|     i86_floppy_disable_controller(); | ||||
|     i86_floppy_enable_controller(); | ||||
|     i86_floppy_wait(); | ||||
|     | ||||
|     int i; | ||||
|     for (i = 0; i < 4; i++) | ||||
|         i86_floppy_check_int(&st0, &cyl); | ||||
|  | ||||
|     unsigned char drive; | ||||
|     for (drive = 0; drive < floppy_drives_installed; drive++) { | ||||
|       i86_floppy_drive_data(drive, 1); | ||||
|       i86_floppy_calibrate(drive); | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_floppy_read_sector_imp (unsigned* where, unsigned char drive, unsigned char head, unsigned char track, unsigned char sector) | ||||
| { | ||||
|     unsigned st0, cyl; | ||||
|  | ||||
|     i86_floppy_select (drive); | ||||
|     i86_floppy_initialize_dma((unsigned char*) where, 512); | ||||
|     i86_dma_set_read(2); | ||||
|  | ||||
|     i86_floppy_new_interrupt = 0; | ||||
|  | ||||
|     i86_floppy_send_command(0x06 | 0x80 | 0x40 ); | ||||
|     i86_floppy_send_command(head<<2 | drive); | ||||
|     i86_floppy_send_command(track); | ||||
|     i86_floppy_send_command(head); | ||||
|     i86_floppy_send_command(sector); | ||||
|     i86_floppy_send_command(0x02); | ||||
|     i86_floppy_send_command( ((sector+1) >= fd[drive].sectors_per_track) ? fd[drive].sectors_per_track : sector+1); | ||||
|     i86_floppy_send_command(0x1b); | ||||
|     i86_floppy_send_command(0xff); | ||||
|  | ||||
|     i86_floppy_wait(); | ||||
|  | ||||
|     int i; | ||||
|     for (i = 0; i < 7; i++) i86_floppy_read_data(); | ||||
|  | ||||
|     i86_floppy_check_int (&st0, &cyl); | ||||
| } | ||||
|  | ||||
|  | ||||
| unsigned char i86_floppy_seek (unsigned drive, unsigned cyl, unsigned head) | ||||
| { | ||||
|     unsigned st0, cyl0; | ||||
|  | ||||
|     if (drive >= floppy_drives_installed) return 0; | ||||
|  | ||||
|     i86_floppy_select (drive); | ||||
|  | ||||
|     int i; | ||||
|     for (i = 0; i < 20; i++) { | ||||
|         i86_floppy_new_interrupt = 0; | ||||
|         i86_floppy_send_command (0xF); | ||||
|         i86_floppy_send_command ( (head) << 2 | drive); | ||||
|         i86_floppy_send_command (cyl); | ||||
|  | ||||
|         i86_floppy_wait(); | ||||
|         i86_floppy_check_int(&st0, &cyl0); | ||||
|  | ||||
|         if (cyl0 == cyl) return 1; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void i86_floppy_lba_to_chs (int lba, unsigned char drive, unsigned char *head, unsigned char *track, unsigned char *sectors) | ||||
| { | ||||
|     *head = (lba % (fd[drive].sectors_per_track * 2)) / fd[drive].sectors_per_track; | ||||
|     *track = lba / (fd[drive].sectors_per_track * 2); | ||||
|     *sectors = lba % fd[drive].sectors_per_track + 1; | ||||
| } | ||||
|  | ||||
| extern unsigned char i86_cmos_read_floppy_drives(); | ||||
| const char* types[] = { | ||||
|       "Nonexistant", "5.25\", unsupported.", "5.25\", unsupported.", | ||||
|       "3.5\", 720kb", "3.5\", 1.44mb", "3.5\", 2.88 mb"}; | ||||
|  | ||||
| void i86_floppy_install() | ||||
| { | ||||
|     unsigned char temp = i86_cmos_read_floppy_drives(); | ||||
|     int i; | ||||
|  | ||||
|     // Set fd0 and fd1 types | ||||
|     fd[1].type = temp & 0xf; | ||||
|     fd[0].type = temp >> 4; | ||||
|      | ||||
|     // SRT = 16 - (ms * datarate / 500000); | ||||
|     // HLT = ms * datarate / 1000000 | ||||
|     // HUT = ms * datarate / 8000000 | ||||
|  | ||||
|     // Set up | ||||
|     for (i = 0; i < 2; i++) { | ||||
|         if (fd[i].type >= 3) floppy_drives_installed++; // 5.25" drives unsupported | ||||
|         if (fd[i].type == 3) {  // 720 kb, DD | ||||
|                 fd[i].data_rate = 2;      // speed = 250 kbps | ||||
|                 fd[i].step_rate_time = 12; // 16 - (ms * 250000 / 500000), ms = 8 | ||||
|                 fd[i].head_load_time = 7; | ||||
|                 fd[i].head_unload_time = 7; | ||||
|                 fd[i].sectors_per_track = 9; | ||||
|         } | ||||
|         else if (fd[i].type == 4) { // 1.44 MB, HD | ||||
|                 fd[i].data_rate = 0;      // speed = 500 kbps | ||||
|                 fd[i].step_rate_time = 8; | ||||
|                 fd[i].head_load_time = 15; | ||||
|                 fd[i].head_unload_time = 15; | ||||
|                 fd[i].sectors_per_track = 18; | ||||
|         } | ||||
|         else if (fd[i].type == 5) { // 2.88 MB, ED | ||||
|                 fd[i].data_rate = 3;      // speed = 1000 kbps; | ||||
|                 fd[i].step_rate_time = 0; | ||||
|                 fd[i].head_load_time = 30; | ||||
|                 fd[i].head_unload_time = 30; | ||||
|                 fd[i].sectors_per_track = 36; | ||||
|         } | ||||
|     } | ||||
|     if (floppy_drives_installed == 0) return;       // No drives to set | ||||
|  | ||||
|     // Install handler | ||||
|     i86_irq_install_handler(6, i86_floppy_handler); | ||||
|     i86_floppy_reset(); | ||||
| } | ||||
|  | ||||
|  | ||||
| unsigned char i86_floppy_driver_enabled() | ||||
| { | ||||
|     return (floppy_drives_installed>0); | ||||
| } | ||||
|  | ||||
|  | ||||
| unsigned* i86_read_sector (unsigned* where, unsigned char drive, int sectorLBA) | ||||
| { | ||||
|     if (drive >= floppy_drives_installed) return 0; | ||||
|     if ((unsigned)(where) > (0xFFFF - 513)) return 0; | ||||
|  | ||||
|     // convert lba to chs | ||||
|     unsigned head, track, sector; | ||||
|     i86_floppy_lba_to_chs(sectorLBA, drive, (unsigned char*)&head, (unsigned char*)&track, (unsigned char*) §or); | ||||
|  | ||||
|     // start motor | ||||
|     i86_floppy_motor(drive, 1); | ||||
|     if (!i86_floppy_seek(drive, track, head)) return 0; | ||||
|  | ||||
|     i86_floppy_read_sector_imp(where, drive, head, track, sector); | ||||
|     i86_floppy_motor(drive, 0); | ||||
|  | ||||
|     return (unsigned*)where; | ||||
| } | ||||
							
								
								
									
										19
									
								
								SysCore/hal/floppy/floppy.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								SysCore/hal/floppy/floppy.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| /***** floppy.h ****************************************************** | ||||
|  * (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
|  *                                                                   * | ||||
|  *         Floppy Drive I/O Routines                                 * | ||||
|  *         =========================                                 * | ||||
|  *                                                                   * | ||||
|  ************************************************************ cta os */ | ||||
|  | ||||
| extern unsigned char i86_floppy_initialize_dma(unsigned char* buffer, unsigned length); | ||||
| extern void i86_floppy_motor (unsigned char drive, unsigned char on); | ||||
| extern void i86_floppy_handler(ISR_stack_regs *r); | ||||
| extern void i86_floppy_drive_data (unsigned char drv, unsigned char dma); | ||||
| extern unsigned char i86_floppy_calibrate(unsigned drive); | ||||
| extern void i86_floppy_reset(); | ||||
| extern void i86_floppy_read_sector_imp (unsigned* where, unsigned char drive, unsigned char head, unsigned char track, unsigned char sector); | ||||
| extern unsigned char i86_floppy_seek (unsigned drive, unsigned cyl, unsigned head); | ||||
| extern void i86_floppy_install(); | ||||
| extern unsigned char i86_floppy_driver_enabled(); | ||||
| extern unsigned* i86_read_sector (unsigned* where, unsigned char drive, int sectorLBA); | ||||
| @@ -2,7 +2,7 @@ | ||||
|  *    gdt.c  -  GLOBAL DESCRIPTOR TABLE                           * | ||||
|  *      Contains function prototypes for setting up the GDT       * | ||||
|  ******************************************************************/ | ||||
| #define MAX_DESCRIPTORS 3 | ||||
| #define MAX_DESCRIPTORS 5 | ||||
| #include "gdt.h" | ||||
|  | ||||
| /* Our GDT, with 3 entries, and finally our special GDT pointer */ | ||||
| @@ -59,6 +59,12 @@ void i86_gdt_install() | ||||
|     *  this entry's access byte says it's a Data Segment */ | ||||
|     i86_gdt_set_gate(2, 0, 0xFFFFFFFF, 0x92, 0xCF); | ||||
|  | ||||
|     /* User mode Code segment*/ | ||||
|     i86_gdt_set_gate(3, 0, 0xFFFFFFFF, 0xFA, 0xCF); | ||||
|      | ||||
|     /* User mode data segment*/ | ||||
|     i86_gdt_set_gate(4, 0, 0xFFFFFFFF, 0xF2, 0xCF); | ||||
|  | ||||
|     /* Flush out the old GDT and install the new changes! */ | ||||
|     i86_gdt_flush(); | ||||
| } | ||||
|   | ||||
| @@ -10,24 +10,26 @@ | ||||
| #include "irq/irq.h" | ||||
| #include "isrs/isrs.h" | ||||
| #include "keyboard/keyus.h" | ||||
| #include "floppy/floppy.h" | ||||
|  | ||||
| // initialize hardware devices | ||||
| void i86_hal_initialize () { | ||||
|  | ||||
| 	// initialize motherboard controllers and system timer | ||||
| 	i86_cpu_initialize ();  // (install GDT, IDT) | ||||
| 	i86_isrs_install();     // (install ISR handler) | ||||
|       i86_irq_install();      // (install IRQ handler) | ||||
|     // initialize motherboard controllers and system timer | ||||
|         i86_cpu_initialize ();  // (install GDT, IDT) | ||||
|         i86_isrs_install();     // (install ISR handler) | ||||
|         i86_irq_install();      // (install IRQ handler) | ||||
|        | ||||
|       // install PIT and system clock; pit at 100 Hz | ||||
|       i86_kb_install_partone(); | ||||
|       i86_cmos_read_clock((TIME*)&_internal_clock); | ||||
|     // install PIT and system clock; pit at 100 Hz | ||||
|         i86_kb_install_partone(); | ||||
|         i86_cmos_read_clock((TIME*)&_internal_clock); | ||||
| 	i86_pit_install (100); | ||||
| 	i86_kb_install_parttwo(); | ||||
| 	 | ||||
|     // enable interrupts | ||||
|         i86_start_interrupts(); | ||||
|  | ||||
| 	// enable interrupts | ||||
| 	i86_start_interrupts(); | ||||
|  | ||||
|         i86_floppy_install(); | ||||
| } | ||||
|  | ||||
| // shutdown hardware devices | ||||
| @@ -46,58 +48,14 @@ void reboot() | ||||
|     __asm__ __volatile__ ("hlt"); | ||||
| } | ||||
|  | ||||
| //! notifies hal interrupt is done | ||||
| /*inline void interruptdone (unsigned int intno) { | ||||
|  | ||||
| 	//! insure its a valid hardware irq | ||||
| 	if (intno > 16) | ||||
| 		return; | ||||
|  | ||||
| 	//! test if we need to send end-of-interrupt to second pic | ||||
| 	if (intno >= 8) | ||||
| 		i86_pic_send_command (0x20, 0xA1); | ||||
|  | ||||
| 	//! always send end-of-interrupt to primary pic | ||||
| 	i86_pic_send_command (0x20, 0x21); | ||||
| } | ||||
| */ | ||||
|  | ||||
| //! output sound to speaker | ||||
| void 	sound (unsigned frequency) { | ||||
|  | ||||
| 	//! sets frequency for speaker. frequency of 0 disables speaker | ||||
| 	outportb (0x61, 3 | (byte)(frequency<<2) ); | ||||
| 	outportb (0x61, 3 | (unsigned char)(frequency<<2) ); | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| //! sets new interrupt vector | ||||
| /*void _cdecl setvect (int intno, void (_cdecl far &vect) ( ) ) { | ||||
|  | ||||
| 	//! install interrupt handler! This overwrites prev interrupt descriptor | ||||
| 	i86_install_ir (intno, I86_IDT_DESC_PRESENT | I86_IDT_DESC_BIT32, | ||||
| 		0x8, vect); | ||||
| } | ||||
|  | ||||
|  | ||||
| //! returns current interrupt vector | ||||
| void (_cdecl far * _cdecl	getvect (int intno)) ( ) { | ||||
|  | ||||
| 	//! get the descriptor from the idt | ||||
| 	idt_descriptor* desc = i86_get_ir (intno); | ||||
| 	if (!desc) | ||||
| 		return 0; | ||||
|  | ||||
| 	//! get address of interrupt handler | ||||
| 	uint32_t addr = desc->baseLo | (desc->baseHi << 16); | ||||
|  | ||||
| 	//! return interrupt handler | ||||
| 	I86_IRQ_HANDLER irq = (I86_IRQ_HANDLER)addr; | ||||
| 	return irq; | ||||
| } | ||||
|  | ||||
| */ | ||||
| //! returns cpu vender | ||||
| const char* get_cpu_vender () { | ||||
|  | ||||
| @@ -108,19 +66,18 @@ const char* get_cpu_vender () { | ||||
| /*************************************************************************************** | ||||
|  *                     Keyboard Routines                                               * | ||||
|  ***************************************************************************************/ | ||||
| char getch() | ||||
| /*char getch() | ||||
| { | ||||
|       kb_key alpha = getkey(); | ||||
|       return alpha.character; | ||||
| } | ||||
|  -> moved in conio library | ||||
| }*/ | ||||
|  | ||||
| char scancode_to_ascii(byte scancode, byte status) | ||||
| char scancode_to_ascii(unsigned char scancode, unsigned char status) | ||||
| { | ||||
|       if ((status&1) || (status&2)) return kbdus_map_shift[scancode]; | ||||
|       else return kbdus_map[scancode]; | ||||
| } | ||||
|  | ||||
| byte get_key_status (byte scancode) | ||||
| unsigned char get_key_status (unsigned char scancode) | ||||
| { | ||||
|       if (scancode&0xF0) return kb_lights_status&0x0F; | ||||
|       else if (scancode&0x80) return kb_modifier_status&0x7F; | ||||
| @@ -153,7 +110,7 @@ void kb_set_repeat(float rate, int delay){ | ||||
|                         3.7, 3.3, 3.0, 2.7, 2.5, 2.3, 2.1, 2.0} ; | ||||
|  | ||||
|  | ||||
|       byte r,d; | ||||
|       unsigned char r,d; | ||||
|        | ||||
|       for (r = 0; rate != rates[r] && r < 32; r++) | ||||
|       if (rate==32) return; | ||||
| @@ -179,6 +136,6 @@ void kb_set_repeat(float rate, int delay){ | ||||
|  |(reserved) |  lock |  lock |  lock  | | ||||
|  +-----------+-------+-------+--------+ | ||||
|  ***************************************/  | ||||
| void kb_set_LEDs(byte status) { | ||||
| void kb_set_LEDs(unsigned char status) { | ||||
|       i86_kb_set_LEDs(status); | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,8 @@ | ||||
| #ifndef __IRQ_H | ||||
| #define __IRQ_H | ||||
|  | ||||
| #include <regs.h> | ||||
|  | ||||
| /* These are own ISRs that point to our special IRQ handler | ||||
| *  instead of the regular 'fault_handler' function */ | ||||
|  | ||||
|   | ||||
| @@ -36,10 +36,10 @@ char *exception_messages[] = { | ||||
| }; | ||||
|  | ||||
|  | ||||
| void _STOP_ERROR_SCREEN (ISR_stack_regs *r) | ||||
| { | ||||
|         set_default_colors (0x01, 0x0F); clrscr(); | ||||
|         puts ("                              Blue Screen Of Death\n"); | ||||
| //void _STOP_ERROR_SCREEN (ISR_stack_regs *r) | ||||
| //{ | ||||
|         //set_default_colors (0x01, 0x0F); clrscr(); | ||||
|         /*puts_pos (0, 0, "                              Blue Screen Of Death\n"); | ||||
|         int i; for (i = 79; i>=0; i--) putc('='); | ||||
|         puts_pos_font (15, 2, "A fatal error has occured, CTA OS has been halted.", 0x01, 0x0C); | ||||
|         puts_pos_font (10, 4, "gs", 0x01, 0x0B); put_hex_pos(15, 4, r->gs); | ||||
| @@ -67,8 +67,8 @@ void _STOP_ERROR_SCREEN (ISR_stack_regs *r) | ||||
|         puts_pos_font (10, 20, "useresp", 0x01, 0x0B); put_hex_pos(17, 20, r->useresp); | ||||
|         puts_pos_font (10, 21, "ss", 0x01, 0x0B); put_hex_pos(17, 21, r->ss); | ||||
|          | ||||
|         puts_pos_font (29, 24, "!!! System  Halted !!!", 0x01, 0x0C); | ||||
| } | ||||
|         puts_pos_font (29, 24, "!!! System  Halted !!!", 0x01, 0x0C);*/ | ||||
| //} | ||||
|  | ||||
| /*void _STOP_ERROR_SCREEN (ISR_stack_regs *r) | ||||
| { | ||||
| @@ -76,4 +76,9 @@ void _STOP_ERROR_SCREEN (ISR_stack_regs *r) | ||||
|         puts_pos(50, 24, exception_messages[r->int_no]); | ||||
|          | ||||
|         puts_pos_font (5, 24, "!!! System  Halted !!!", 0x01, 0x0C); | ||||
| }*/ | ||||
| }*/ | ||||
|  | ||||
| void _STOP_ERROR_SCREEN (ISR_stack_regs *r) | ||||
| { | ||||
|     cprintf ("%#0C** Fatal Error: "); cprintf("%#0E %s \n\r", exception_messages[r->int_no]); | ||||
| } | ||||
| @@ -6,128 +6,130 @@ | ||||
| #define KB_KEY_LCTRL  0x90    // 1001 0000 | ||||
| #define KB_KEY_RCTRL  0xA0    // 1010 0000 | ||||
| #define KB_KEY_FSHIFT 0xC0    // 1100 0000 | ||||
| extern volatile byte kb_modifier_status; | ||||
| extern volatile unsigned char kb_modifier_status; | ||||
|  | ||||
| #define KB_PREFIX_GRAY   0x01       // Gray | ||||
| #define KB_PREFIX_BREAK  0x02       // Break code | ||||
| #define KB_PREFIX_PAUSE  0x04       // Pause/break key | ||||
| #define KB_PREFIX_PAUSE1 0x08       // Recieved first byte from pause/break | ||||
| extern volatile byte kb_prefix; | ||||
| #define KB_PREFIX_PAUSE1 0x08       // Recieved first unsigned char from pause/break | ||||
| extern volatile unsigned char kb_prefix; | ||||
|  | ||||
| #define KB_KEY_SCROLL  0xF1   // 1111 0001 | ||||
| #define KB_KEY_NUM     0xF2   // 1111 0010 | ||||
| #define KB_KEY_CAPS    0xF4   // 1111 0100 | ||||
| extern volatile byte kb_lights_status; | ||||
| extern volatile unsigned char kb_lights_status; | ||||
|  | ||||
| extern byte kb_scancode_set; | ||||
| #define KB_KEY_PAUSE                0x00 | ||||
| #define KB_KEY_F9                   0x01 | ||||
| #define KB_KEY_F7                   0x02 | ||||
| #define KB_KEY_F5                   0X03 | ||||
| #define KB_KEY_F3                   0x04 | ||||
| #define KB_KEY_F1                   0x05 | ||||
| #define KB_KEY_F2                   0x06 | ||||
| #define KB_KEY_F12                  0x07 | ||||
| #define KB_KEY_PRINTSCRN            0x08 | ||||
| #define KB_KEY_F10                  0x09 | ||||
| #define KB_KEY_F8                   0x0A | ||||
| #define KB_KEY_F6                   0x0B | ||||
| #define KB_KEY_F4                   0x0C | ||||
| #define KB_KEY_TAB                  0x0D | ||||
| #define KB_KEY_TILDA                0x0E | ||||
| #define KB_KEY_Q                    0x15 | ||||
| #define KB_KEY_1                    0x16 | ||||
| #define KB_KEY_Z                    0x1A | ||||
| #define KB_KEY_S                    0x1B | ||||
| #define KB_KEY_A                    0x1C | ||||
| #define KB_KEY_W                    0x1D | ||||
| #define KB_KEY_2                    0x1E | ||||
| #define KB_KEY_LWIN                 0x1F | ||||
| #define KB_KEY_C                    0x21 | ||||
| #define KB_KEY_X                    0x22 | ||||
| #define KB_KEY_D                    0x23 | ||||
| #define KB_KEY_E                    0x24 | ||||
| #define KB_KEY_4                    0x25 | ||||
| #define KB_KEY_3                    0x26 | ||||
| #define KB_KEY_RWIN                 0x27 | ||||
| #define KB_KEY_SPACE                0x29 | ||||
| #define KB_KEY_V                    0x2A | ||||
| #define KB_KEY_F                    0x2B | ||||
| #define KB_KEY_T                    0x2C | ||||
| #define KB_KEY_R                    0x2D | ||||
| #define KB_KEY_5                    0x2E | ||||
| #define KB_KEY_MENU                 0x2F | ||||
| #define KB_KEY_N                    0x31 | ||||
| #define KB_KEY_B                    0x32 | ||||
| #define KB_KEY_H                    0x33 | ||||
| #define KB_KEY_G                    0x34 | ||||
| #define KB_KEY_Y                    0x35 | ||||
| #define KB_KEY_6                    0x36 | ||||
| #define KB_KEY_M                    0x3A | ||||
| #define KB_KEY_J                    0x3B | ||||
| #define KB_KEY_U                    0x3C | ||||
| #define KB_KEY_7                    0x3D | ||||
| #define KB_KEY_8                    0x3E | ||||
| #define KB_KEY_COMMA                0x41 | ||||
| #define KB_KEY_K                    0x42 | ||||
| #define KB_KEY_I                    0x43 | ||||
| #define KB_KEY_O                    0x44 | ||||
| #define KB_KEY_0                    0x45 | ||||
| #define KB_KEY_9                    0x46 | ||||
| #define KB_KEY_PERIOD               0x49 | ||||
| #define KB_KEY_SLASH                0x4A | ||||
| #define KB_KEY_L                    0x4B | ||||
| #define KB_KEY_SEMICOLON            0x4C | ||||
| #define KB_KEY_P                    0x4D | ||||
| #define KB_KEY_DASH                 0x4E | ||||
| #define KB_KEY_APOSTROPHE           0x52 | ||||
| #define KB_KEY_LBRACKET             0x54 | ||||
| #define KB_KEY_EQUAL                0x55 | ||||
| #define KB_KEY_NUMPAD_ENTER         0x59 | ||||
| #define KB_KEY_ENTER                0x5A | ||||
| #define KB_KEY_RBRACKET             0x5B | ||||
| #define KB_KEY_BACKSLASH            0x5D | ||||
| #define KB_KEY_END                  0x5E | ||||
| #define KB_KEY_LEFT                 0x5F | ||||
| #define KB_KEY_HOME                 0x60 | ||||
| #define KB_KEY_INSERT               0x61 | ||||
| #define KB_KEY_DELETE               0x62 | ||||
| #define KB_KEY_DOWN                 0x63 | ||||
| #define KB_KEY_RIGHT                0x64 | ||||
| #define KB_KEY_UP                   0x65 | ||||
| #define KB_KEY_BACKSPACE            0x66 | ||||
| #define KB_KEY_PGDOWN               0x67 | ||||
| #define KB_KEY_PGUP                 0x68 | ||||
| #define KB_KEY_NUMPAD_1             0x69 | ||||
| #define KB_KEY_NUMPAD_SLASH         0x6A | ||||
| #define KB_KEY_NUMPAD_4             0x6B | ||||
| #define KB_KEY_NUMPAD_7             0x6C | ||||
| #define KB_KEY_NUMPAD_0             0x70 | ||||
| #define KB_KEY_NUMPAD_COLON         0x71 | ||||
| #define KB_KEY_NUMPAD_2             0x72 | ||||
| #define KB_KEY_NUMPAD_5             0x73 | ||||
| #define KB_KEY_NUMPAD_6             0x74 | ||||
| #define KB_KEY_NUMPAD_8             0x75 | ||||
| #define KB_KEY_ESC                  0x76 | ||||
| #define KB_KEY_F11                  0x78 | ||||
| #define KB_KEY_NUMPAD_PLUS          0x79 | ||||
| #define KB_KEY_NUMPAD_3             0x7A | ||||
| #define KB_KEY_NUMPAD_MINUS         0x7B | ||||
| #define KB_KEY_NUMPAD_ASTERISK      0x7C | ||||
| #define KB_KEY_NUMPAD_9             0x7D | ||||
| extern unsigned char kb_scancode_set; | ||||
|  | ||||
| enum KB_KEYS { | ||||
|        KB_KEY_PAUSE         =      0x00 | ||||
|        KB_KEY_F9            =      0x01 | ||||
|        KB_KEY_F7            =      0x02 | ||||
|        KB_KEY_F5            =      0X03 | ||||
|        KB_KEY_F3            =      0x04 | ||||
|        KB_KEY_F1            =      0x05 | ||||
|        KB_KEY_F2            =      0x06 | ||||
|        KB_KEY_F12           =      0x07 | ||||
|        KB_KEY_PRINTSCRN     =      0x08 | ||||
|        KB_KEY_F10           =      0x09 | ||||
|        KB_KEY_F8            =      0x0A | ||||
|        KB_KEY_F6            =      0x0B | ||||
|        KB_KEY_F4            =      0x0C | ||||
|        KB_KEY_TAB           =      0x0D | ||||
|        KB_KEY_TILDA         =      0x0E | ||||
|        KB_KEY_Q             =      0x15 | ||||
|        KB_KEY_1             =      0x16 | ||||
|        KB_KEY_Z             =      0x1A | ||||
|        KB_KEY_S             =      0x1B | ||||
|        KB_KEY_A             =      0x1C | ||||
|        KB_KEY_W             =      0x1D | ||||
|        KB_KEY_2             =      0x1E | ||||
|        KB_KEY_LWIN          =      0x1F | ||||
|        KB_KEY_C             =      0x21 | ||||
|        KB_KEY_X             =      0x22 | ||||
|        KB_KEY_D             =      0x23 | ||||
|        KB_KEY_E             =      0x24 | ||||
|        KB_KEY_4             =      0x25 | ||||
|        KB_KEY_3             =      0x26 | ||||
|        KB_KEY_RWIN          =      0x27 | ||||
|        KB_KEY_SPACE         =      0x29 | ||||
|        KB_KEY_V             =      0x2A | ||||
|        KB_KEY_F             =      0x2B | ||||
|        KB_KEY_T             =      0x2C | ||||
|        KB_KEY_R             =      0x2D | ||||
|        KB_KEY_5             =      0x2E | ||||
|        KB_KEY_MENU          =      0x2F | ||||
|        KB_KEY_N             =      0x31 | ||||
|        KB_KEY_B             =      0x32 | ||||
|        KB_KEY_H             =      0x33 | ||||
|        KB_KEY_G             =      0x34 | ||||
|        KB_KEY_Y             =      0x35 | ||||
|        KB_KEY_6             =      0x36 | ||||
|        KB_KEY_M             =      0x3A | ||||
|        KB_KEY_J             =      0x3B | ||||
|        KB_KEY_U             =      0x3C | ||||
|        KB_KEY_7             =      0x3D | ||||
|        KB_KEY_8             =      0x3E | ||||
|        KB_KEY_COMMA         =      0x41 | ||||
|        KB_KEY_K             =      0x42 | ||||
|        KB_KEY_I             =      0x43 | ||||
|        KB_KEY_O             =      0x44 | ||||
|        KB_KEY_0             =      0x45 | ||||
|        KB_KEY_9             =      0x46 | ||||
|        KB_KEY_PERIOD        =      0x49 | ||||
|        KB_KEY_SLASH         =      0x4A | ||||
|        KB_KEY_L             =      0x4B | ||||
|        KB_KEY_SEMICOLON     =      0x4C | ||||
|        KB_KEY_P             =      0x4D | ||||
|        KB_KEY_DASH          =      0x4E | ||||
|        KB_KEY_APOSTROPHE    =      0x52 | ||||
|        KB_KEY_LBRACKET      =      0x54 | ||||
|        KB_KEY_EQUAL         =      0x55 | ||||
|        KB_KEY_NUMPAD_ENTER  =      0x59 | ||||
|        KB_KEY_ENTER         =      0x5A | ||||
|        KB_KEY_RBRACKET      =      0x5B | ||||
|        KB_KEY_BACKSLASH     =      0x5D | ||||
|        KB_KEY_END           =      0x5E | ||||
|        KB_KEY_LEFT          =      0x5F | ||||
|        KB_KEY_HOME          =      0x60 | ||||
|        KB_KEY_INSERT        =      0x61 | ||||
|        KB_KEY_DELETE        =      0x62 | ||||
|        KB_KEY_DOWN          =      0x63 | ||||
|        KB_KEY_RIGHT         =      0x64 | ||||
|        KB_KEY_UP            =      0x65 | ||||
|        KB_KEY_BACKSPACE     =      0x66 | ||||
|        KB_KEY_PGDOWN        =      0x67 | ||||
|        KB_KEY_PGUP          =      0x68 | ||||
|        KB_KEY_NUMPAD_1      =      0x69 | ||||
|        KB_KEY_NUMPAD_SLASH  =      0x6A | ||||
|        KB_KEY_NUMPAD_4      =      0x6B | ||||
|        KB_KEY_NUMPAD_7      =      0x6C | ||||
|        KB_KEY_NUMPAD_0      =      0x70 | ||||
|        KB_KEY_NUMPAD_COLON  =      0x71 | ||||
|        KB_KEY_NUMPAD_2      =      0x72 | ||||
|        KB_KEY_NUMPAD_5      =      0x73 | ||||
|        KB_KEY_NUMPAD_6      =      0x74 | ||||
|        KB_KEY_NUMPAD_8      =      0x75 | ||||
|        KB_KEY_ESC           =      0x76 | ||||
|        KB_KEY_F11           =      0x78 | ||||
|        KB_KEY_NUMPAD_PLUS   =      0x79 | ||||
|        KB_KEY_NUMPAD_3      =      0x7A | ||||
|        KB_KEY_NUMPAD_MINUS  =      0x7B | ||||
|        KB_KEY_NUMPAD_ASTERISK =    0x7C | ||||
|        KB_KEY_NUMPAD_9      =      0x7D | ||||
| }; | ||||
|        | ||||
| typedef struct { | ||||
|       byte status; | ||||
|       byte lights; | ||||
|       byte scancode; | ||||
|       byte character; | ||||
|       unsigned char status; | ||||
|       unsigned char lights; | ||||
|       unsigned char scancode; | ||||
|       unsigned char character; | ||||
| } kb_key; | ||||
|  | ||||
|  | ||||
| extern char getch(); | ||||
| extern kb_key get_key(); | ||||
| extern scancode_to_ascii(byte scancode); | ||||
| extern byte get_key_status(byte scancode); | ||||
| extern scancode_to_ascii(unsigned char scancode); | ||||
| extern unsigned char get_key_status(unsigned char scancode); | ||||
| extern void kb_set_repeat(float rate, int delay); | ||||
| extern void kb_set_LEDs(byte status); | ||||
| extern void kb_set_LEDs(unsigned char status); | ||||
| @@ -28,18 +28,18 @@ const char kbdus_map_shift[] = { | ||||
|       }; | ||||
|  | ||||
|  | ||||
| volatile byte kb_array[16]; | ||||
| volatile byte kb_newdata; | ||||
| volatile byte kb_modifier_status; | ||||
| volatile byte kb_prefix; | ||||
| volatile byte kb_lights_status; | ||||
| byte kb_scancode_set; | ||||
| volatile unsigned char kb_array[16]; | ||||
| volatile unsigned char kb_newdata; | ||||
| volatile unsigned char kb_modifier_status; | ||||
| volatile unsigned char kb_prefix; | ||||
| volatile unsigned char kb_lights_status; | ||||
| unsigned char kb_scancode_set; | ||||
|  | ||||
|  | ||||
| void i86_kb_set_key(byte scancode, byte val) | ||||
| void i86_kb_set_key(unsigned char scancode, unsigned char val) | ||||
| { | ||||
|       byte pos = scancode/8; | ||||
|       byte offset = scancode%8; | ||||
|       unsigned char pos = scancode/8; | ||||
|       unsigned char offset = scancode%8; | ||||
|        | ||||
|       if (val) { | ||||
|             kb_array[pos] |= 1<<offset; | ||||
| @@ -48,16 +48,16 @@ void i86_kb_set_key(byte scancode, byte val) | ||||
|       else kb_array[pos] &= 0xFF - (1<<offset); | ||||
| } | ||||
|  | ||||
| byte i86_kb_get_key(byte scancode) | ||||
| unsigned char i86_kb_get_key(unsigned char scancode) | ||||
| { | ||||
|       byte pos = scancode/8; | ||||
|       byte offset = scancode%8; | ||||
|       unsigned char pos = scancode/8; | ||||
|       unsigned char offset = scancode%8; | ||||
|       return (kb_array[pos]&(1<<offset)); | ||||
| } | ||||
|  | ||||
|  | ||||
| void i86_kb_handler(ISR_stack_regs *r) { | ||||
|       byte scancode = inportb(0x60); | ||||
|       unsigned char scancode = inportb(0x60); | ||||
|  | ||||
|       switch (scancode) { | ||||
|             case 0x00:                                      // Error 0x00 | ||||
| @@ -165,7 +165,6 @@ void i86_kb_handler(ISR_stack_regs *r) { | ||||
|             if (ok==2) reboot(); | ||||
|             } | ||||
|        | ||||
|       outportb(0x20, 0x20); | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -210,11 +209,11 @@ kb_key getkey() | ||||
|   250 | 500 | 750 | 1000 | ||||
|    | ||||
|  ***************************************/  | ||||
| void i86_kb_set_repeat(byte rate, byte delay) | ||||
| void i86_kb_set_repeat(unsigned char rate, unsigned char delay) | ||||
| { | ||||
|       if (rate>3 || delay>31) return; | ||||
|  | ||||
|       byte out = rate<<5 | delay; | ||||
|       unsigned char out = rate<<5 | delay; | ||||
|       while ((inportb(0x64)&2) != 0); | ||||
|       outportb(0x60, 0xF3); | ||||
|       while ((inportb(0x64)&2) != 0); | ||||
| @@ -231,7 +230,7 @@ void i86_kb_set_repeat(byte rate, byte delay) | ||||
|  |(reserved) |  lock |  lock |  lock  | | ||||
|  +-----------+-------+-------+--------+ | ||||
|  ***************************************/  | ||||
| void i86_kb_set_LEDs(byte status) | ||||
| void i86_kb_set_LEDs(unsigned char status) | ||||
| { | ||||
|     while ((inportb (0x64)&2)!=0); | ||||
|     outportb (0x60, 0xED); | ||||
| @@ -248,7 +247,7 @@ void i86_kb_set_LEDs(byte status) | ||||
|       2  Set to scancode set 2 | ||||
|       3  Set to scancode set 3 | ||||
|  ***************************************/  | ||||
| void i86_kb_set_scancodeset(byte set) | ||||
| void i86_kb_set_scancodeset(unsigned char set) | ||||
| { | ||||
|     if (set>3) return; | ||||
|      | ||||
| @@ -261,7 +260,7 @@ void i86_kb_set_scancodeset(byte set) | ||||
|     kb_scancode_set = set; | ||||
| } | ||||
|  | ||||
| byte i86_kb_get_scancodeset() { | ||||
| unsigned char i86_kb_get_scancodeset() { | ||||
|       return kb_scancode_set; | ||||
| } | ||||
|  | ||||
| @@ -298,7 +297,7 @@ int i86_kb_install_parttwo() | ||||
|       int ret = 0; | ||||
|  | ||||
|       // Wait for BAT test results | ||||
|       byte temp; | ||||
|       unsigned char temp; | ||||
|       do temp = inportb(0x60); | ||||
|       while (temp!=0xAA && temp!=0xFC); | ||||
|  | ||||
| @@ -311,13 +310,13 @@ int i86_kb_install_parttwo() | ||||
|       i86_kb_set_scancodeset(2);  // Set new scancode set | ||||
|  | ||||
|       i86_kb_waitin(); | ||||
|       outportb(0x64, 0x20); // Get "Command byte" | ||||
|       outportb(0x64, 0x20); // Get "Command unsigned char" | ||||
|        | ||||
|       do {  temp = inportb(0x60); | ||||
|       } while (temp==0xFA || temp==0xAA); | ||||
|        | ||||
|       temp &= 0xFF - (1<<6); // Set bit6 to 0: disable conversion | ||||
|       i86_kb_waitin(); outportb(0x64, 0x60); // Function to write cmd byte | ||||
|       i86_kb_waitin(); outportb(0x64, 0x60); // Function to write cmd unsigned char | ||||
|       i86_kb_waitin(); outportb(0x60, temp); // Send it | ||||
|       memset((void*)kb_array, 0, 16); | ||||
|  | ||||
|   | ||||
| @@ -4,22 +4,22 @@ | ||||
| extern const char kbdus_map[0x80]; | ||||
| extern const char kbdus_map_shift[0x80]; | ||||
|  | ||||
| extern volatile byte kb_modifier_status; | ||||
| extern volatile byte kb_prefix; | ||||
| extern volatile byte kb_lights_status; | ||||
| extern byte kb_scancode_set; | ||||
| extern volatile unsigned char kb_modifier_status; | ||||
| extern volatile unsigned char kb_prefix; | ||||
| extern volatile unsigned char kb_lights_status; | ||||
| extern unsigned char kb_scancode_set; | ||||
|  | ||||
| extern void i86_kb_set_key(byte scancode, byte val); | ||||
| extern void i86_kb_set_LEDs(byte status); | ||||
| extern void i86_kb_set_repeat(byte rate, byte delay); | ||||
| extern void i86_kb_set_scancodeset(byte set); | ||||
| extern byte i86_kb_get_key(byte scancode); | ||||
| extern void i86_kb_set_key(unsigned char scancode, unsigned char val); | ||||
| extern void i86_kb_set_LEDs(unsigned char status); | ||||
| extern void i86_kb_set_repeat(unsigned char rate, unsigned char delay); | ||||
| extern void i86_kb_set_scancodeset(unsigned char set); | ||||
| extern unsigned char i86_kb_get_key(unsigned char scancode); | ||||
| extern void i86_kb_handler(ISR_stack_regs *r); | ||||
| extern kb_key getkey(); | ||||
| extern void i86_kb_set_repeat(byte rate, byte delay); | ||||
| extern void i86_kb_set_LEDs(byte status); | ||||
| extern void i86_kb_set_scancodeset(byte set); | ||||
| extern byte i86_kb_get_scancodeset(); | ||||
| extern void i86_kb_set_repeat(unsigned char rate, unsigned char delay); | ||||
| extern void i86_kb_set_LEDs(unsigned char status); | ||||
| extern void i86_kb_set_scancodeset(unsigned char set); | ||||
| extern unsigned char i86_kb_get_scancodeset(); | ||||
| extern void i86_kb_waitin(); | ||||
| extern void i86_kb_waitout(); | ||||
| extern void i86_kb_install_partone(); | ||||
|   | ||||
| @@ -30,13 +30,31 @@ goto cmos | ||||
|  | ||||
| :cpu | ||||
|       cd cpu | ||||
|       @echo       * Compiling Central Processing Unit... | ||||
|       @echo       * Compiling Central Processing Unit (CPU)... | ||||
|       del %objpath%\cpu.o | ||||
|       %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/cpu.o cpu.c  | ||||
|       if not exist %objpath%\cpu.o goto error | ||||
|  | ||||
|       cd.. | ||||
|  | ||||
|  | ||||
| :dma | ||||
|       cd dma | ||||
|       @echo       * Compiling Direct Memory Access Controller (DMAC)... | ||||
|       del %objpath%\dma.o | ||||
|       %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/dma.o dma.c  | ||||
|       if not exist %objpath%\dma.o goto error | ||||
|       cd.. | ||||
|  | ||||
|  | ||||
| :floppy | ||||
|       cd floppy | ||||
|       @echo       * Compiling Floppy Driver... | ||||
|       del %objpath%\floppy.o | ||||
|       %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/floppy.o floppy.c | ||||
|       if not exist %objpath%\floppy.o goto error | ||||
|       cd.. | ||||
|  | ||||
| :gdt | ||||
|       cd gdt | ||||
|       @echo       * Compiling Global Descriptor Table... | ||||
|   | ||||
| @@ -50,6 +50,11 @@ void i86_pit_install(int freq) | ||||
|  | ||||
| } | ||||
|  | ||||
| TIME i86_pit_get_time() | ||||
| { | ||||
|     return _internal_clock; | ||||
| } | ||||
|  | ||||
| unsigned char i86_pit_is_initialized() | ||||
| { | ||||
|       return _pit_init; | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| #define __PIT_H | ||||
|  | ||||
| #include<regs.h> | ||||
| extern volatile unsigned int _pit_ticks; | ||||
| extern volatile unsigned int  _pit_ticks; | ||||
| extern volatile unsigned int _pit_frequency; | ||||
| extern volatile TIME _internal_clock; | ||||
|  | ||||
|   | ||||
| @@ -6,32 +6,185 @@ | ||||
|  | ||||
| #include <stdint.h> | ||||
|  | ||||
| //! multiboot info structure passed from boot loader | ||||
| /**The structure used by the VESA Controller Info table.*/ | ||||
| struct _VESA_CONTROLLER_INFO { | ||||
|       /** Vesa signature, should be "VESA". */ | ||||
|       unsigned char     Signature[4]; | ||||
|       /** Version number, example: 0x0300 for VBE 3.0. */ | ||||
|       uint16_t          Version; | ||||
|       /** FAR pointer to OEM string. (seg:offset). */ | ||||
|       uint16_t          OEMString[2]; | ||||
|       /** Capabilities, taken as 4 bytes. */ | ||||
|       uint32_t          Capabilities; | ||||
|       /** Video modes. FAR pointer (seg:offset). */ | ||||
|       uint16_t          VideoModes[2]; | ||||
|       /** Total memory as number of 64k blocks. */ | ||||
|       uint16_t          TotalMemory; | ||||
| } __attribute__((packed)); | ||||
|  | ||||
|  | ||||
| enum _VESA_MODE_ATTRIBUTES { | ||||
|     /** The mode is supported by the present hardware configuration. */ | ||||
|     IsSupported = 0x01, | ||||
|     /** Optional information is available (must be = 1 for VBE v1.2+) */ | ||||
|     OptionalInformation = 0x02, | ||||
|     /** BIOS output is supported. */ | ||||
|     BiosOutput = 0x04, | ||||
|     /** Set if color, clear if monochrome. */ | ||||
|     IsColor = 0x08, | ||||
|     /** Set if graphic mode, clear if text mode. */ | ||||
|     IsGraphic = 0x10, | ||||
|     /** (VBE v2.0+) mode is not VGA compatible. */ | ||||
|     VGACompatible = 0x20, | ||||
|     /** (VBE v2.0+) Bank switched mode not supported. */ | ||||
|     BankSwitchedNotSupported = 0x40, | ||||
|     /** (VBE v2.0+) Linear framebuffer mode supported. */ | ||||
|     LinearFramebufferSupported = 0x80, | ||||
|     /** (VBE v3.0) Interlaced mode available. */ | ||||
|     InterlacedAvailable = 0x100, | ||||
|     /** (VBE/AF v1.0P) Application must call EnableDirrectAccess before calling bank-switching functions. */ | ||||
|     EnableDirectAccess = 0x100, | ||||
|     /** (VBE v3.0) Hardware supports triple buffering. */ | ||||
|     TripleBufferingSupported = 0x200, | ||||
|     /** (VBE v3.0) Hardware supports stereoscopic display. */ | ||||
|     StereoscopicSupported = 0x400, | ||||
|     /** (VBE v3.0) Dual display start address support. */ | ||||
|     DualDisplayStartAddress = 0x800 | ||||
| } VESAModeAttributeMasks; | ||||
|  | ||||
| enum _VESA_MODE_WINDOW_ATTRIBUTES { | ||||
|     /** Window exists. */ | ||||
|     Exists = 0x1, | ||||
|     /** Window is readable. */ | ||||
|     Readable = 0x2, | ||||
|     /** Window is writable. */ | ||||
|     Writable = 0x4 | ||||
| } VESAModeWindowAttributeMasks; | ||||
|  | ||||
| enum _VESA_MODE_MEMORY_MODELS { | ||||
|     /** Text */ | ||||
|     Text = 0x00, | ||||
|     /** CGA graphics*/ | ||||
|     CGA = 0x01, | ||||
|     /** HGC graphics*/ | ||||
|     HGC = 0x02, | ||||
|     /** 16-color EGA grahpics*/ | ||||
|     EGA = 0x03, | ||||
|     /** packed pixel graphics*/ | ||||
|     PackedPixel = 0x04, | ||||
|     /** "sequ 256 (non chain 4) grahpics*/ | ||||
|     Sequ256 = 0x05, | ||||
|     /** Direct color (HiColor, 24bit TrueColor)*/ | ||||
|     DirectColor = 0x06, | ||||
|     /** YUV (luminance-chrominance, also called YIQ)*/ | ||||
|     YUV = 0x07 | ||||
| } VESAModeMemoryModels; | ||||
|  | ||||
| struct _VESA_MODE_INFO { | ||||
|       /** Mode attributes, defined in VESAModeAttributeMasks. */ | ||||
|       uint16_t          Attributes; | ||||
|       /** Window attributes (window A or B), defined in VESAModeWindowAttributeMasks. */ | ||||
|       uint8_t           WindowAttributesA, WindowAttributesB; | ||||
|       /** Window granularity in KB. */ | ||||
|       uint16_t          WindowGranularity; | ||||
|       /** Start segment of window A (0x0000 if not supported).*/ | ||||
|       uint16_t          WindowStartSegmentA; | ||||
|       /** Start segment of window B (0x0000 if not supported).*/ | ||||
|       uint16_t          WindowStartSegmentB; | ||||
|       /** FAR window positioning function (equivalent to AX = 0x4F05. */ | ||||
|       uint32_t          WindowPositioningFunction; | ||||
|       /** Bytes per scanline.*/ | ||||
|       uint16_t          BytesPerScanline; | ||||
|       /** Width in pixels (graphics) or characters (text).*/ | ||||
|       uint16_t          Width; | ||||
|       /** Height in pixels (graphics) or characters (text).*/ | ||||
|       uint16_t          Height; | ||||
|       /** Width of character cell in pixels. */ | ||||
|       uint8_t           CharacterWidth; | ||||
|       /** Height of character cell in pixels. */ | ||||
|       uint8_t           CharacterHeight; | ||||
|       /** Number of memory planes. */ | ||||
|       uint8_t           MemoryPlanes; | ||||
|       /** Number of bits per pixel. */ | ||||
|       uint8_t           Bpp; | ||||
|       /** Number of banks.*/ | ||||
|       uint8_t           Banks; | ||||
|       /** Memory model type, defined in VESAModeMemoryModels.*/ | ||||
|       uint8_t           MemoryModelType; | ||||
|       /** Size of bank in KB. */ | ||||
|       uint8_t           BankSize; | ||||
|       /** Number of image pages minus one, that will fit in video RAM.*/ | ||||
|       uint8_t           ImagePages; | ||||
|       /** Reserved, 0x00 for VBE 1.0 to 2.0, 0x01 for VBE 3.0.*/ | ||||
|       uint8_t           Reserved_0; | ||||
|  | ||||
|       /** (VESA v1.2+) Self explanatory.*/ | ||||
|       uint8_t           RedMaskSize, RedFieldPosition; | ||||
|       uint8_t           GreenMaskSize, GreenFieldPosition; | ||||
|       uint8_t           BlueMaskSize, BlueFieldPosition; | ||||
|       uint8_t           ReservedMaskSize, ReservedFieldPosition; | ||||
|       /** (VESA v1.2+) Direct Color Mode info\n | ||||
|        Bit 0: color ramp is programmable\n | ||||
|        Bit 1: bytes in reserved field may be used by application.*/ | ||||
|       uint8_t           DirectColorModeInfo; | ||||
|       /** (VESA v2.0+) Physical address of linear video buffer.*/ | ||||
|       void*             LinearVideoBuffer; | ||||
|       /** (VESA v2.0+) Pointer to start of offscreen memory.*/ | ||||
|       void*             OffscreenMemory; | ||||
|       /** (VESA v2.0+) KB of offscreen memory.*/ | ||||
|       uint16_t          OffscreenMemorySize; | ||||
|  | ||||
|       /** (VESA v3.0) Bytes per scanline in linear modes.*/ | ||||
|       uint16_t          BytesPerScanlineLinear; | ||||
|       /** (VESA v3.0) Number of images minus one for banked video modes.*/ | ||||
|       uint8_t           ImagesBankedMode; | ||||
|       /** (VESA v3.0) Number of images minus one for linear video modes.*/ | ||||
|       uint8_t           ImagesLinearMode; | ||||
|       /** (VESA v3.0) LINEAR MODES ONLY\n | ||||
|        * \DirectColorMaskSize: size of direct color <color> mask (in bits).\n | ||||
|        * \BitPosition: bit position of <color> mask LSB (e.g. shift count)*/ | ||||
|       uint8_t           RedDirectColorMaskSize, RedBitPosition; | ||||
|       uint8_t           GreenDirectColorMaskSize, GreenBitPosition; | ||||
|       uint8_t           BlueDirectColorMaskSize, BlueBitPosition; | ||||
|       uint8_t           ReservedDirectColorMaskSize, ReservedBitPosition; | ||||
|       /** (VESA v3.0) Maximum pixel clock for graphics video mode, in Hz*/ | ||||
|       uint32_t          MaxPixelClock; | ||||
| } __attribute__ ((packed)); | ||||
|  | ||||
| /**The structure passed by the bootloader. */  | ||||
| typedef struct { | ||||
|       /** How much memory is installed on the system (in KB). */ | ||||
|       uint64_t          Memory; | ||||
|       /** Boot device. */ | ||||
|       uint32_t          BootDevice; | ||||
|       /** Pointer to a char[] string containing kernel parameters. */ | ||||
|       unsigned char*    CommandLine; | ||||
|       /** Number of other modules loaded by the bootloader. */ | ||||
|       uint32_t          ModulesCount; | ||||
|       /** Pointer to where other modules were loaded. */ | ||||
|       void*             ModulesAddress; | ||||
|       /** Size of memory map. */ | ||||
|       uint32_t          MemoryMapLength; | ||||
|       /** Pointer to memory map. */ | ||||
|       void*             MemoryMapAddress; | ||||
|       /** Drives info length. */ | ||||
|       uint32_t          DrivesLength; | ||||
|       /** Pointer to drives info. */ | ||||
|       void*             DrivesAddress; | ||||
|       /** BIOS ROM configuration table. */ | ||||
|       uint32_t          ConfigurationTable; | ||||
|       /** Name of bootloader, should be "CTA" (0 ended string). */ | ||||
|       unsigned char     BootloaderName[4]; | ||||
|       /** APM Table. */ | ||||
|       uint32_t          APMTable; | ||||
|       /** VGA current video mode information. */ | ||||
|       uint8_t           VGACurrentVideoMode; | ||||
|       uint8_t           VGACurrentVideoModeColumns; | ||||
|       uint8_t           VGACurrentVideoPage; | ||||
|       /** VESA video mode(s) information. */ | ||||
|       struct _VESA_CONTROLLER_INFO* VESAControllerInformation; | ||||
|        | ||||
|  | ||||
| 	uint32_t	m_flags; | ||||
| 	uint32_t	m_memoryLo; | ||||
| 	uint32_t	m_memoryHi; | ||||
| 	uint32_t	m_bootDevice; | ||||
| 	uint32_t	m_cmdLine; | ||||
| 	uint32_t	m_modsCount; | ||||
| 	uint32_t	m_modsAddr; | ||||
| 	uint32_t	m_syms0; | ||||
| 	uint32_t	m_syms1; | ||||
| 	uint32_t	m_syms2; | ||||
| 	uint32_t	m_mmap_length; | ||||
| 	uint32_t	m_mmap_addr; | ||||
| 	uint32_t	m_drives_length; | ||||
| 	uint32_t	m_drives_addr; | ||||
| 	uint32_t	m_config_table; | ||||
| 	uint32_t	m_bootloader_name; | ||||
| 	uint32_t	m_apm_table; | ||||
| 	uint32_t	m_vbe_control_info; | ||||
| 	uint32_t	m_vbe_mode_info; | ||||
| 	uint16_t	m_vbe_mode; | ||||
| 	uint32_t	m_vbe_interface_addr; | ||||
| 	uint16_t	m_vbe_interface_len; | ||||
| } multiboot_info ; | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -1,30 +1,104 @@ | ||||
| #ifndef __CONIO_H | ||||
| #define __CONIO_H | ||||
| #define _ATTRIB 0x0F | ||||
|  | ||||
| extern unsigned char default_background, default_foreground; | ||||
| extern char hex[16]; | ||||
| #include <stdlib.h> | ||||
| //#define _ATTRIB 0x0F | ||||
|  | ||||
| extern void itoa (int value, char *string, unsigned int radix); | ||||
| extern int printf(const char* str, ...); | ||||
| extern int abs(int x); | ||||
| extern void graphics_init(); | ||||
| extern void text_mode_cursor(int x, int y); | ||||
| extern void set_default_colors(unsigned char back, unsigned char fore); | ||||
| typedef struct { | ||||
|     /** Console window width. */ | ||||
|     unsigned width; | ||||
|     /** Console window height. */ | ||||
|     unsigned height; | ||||
|     /** Default colors (can be changed later with ConsoleSetDefaultColors() routine)*/ | ||||
|     unsigned char defcolors; | ||||
|     /** Pointer to a routine to set the blinking cursor position.\n | ||||
|      Parameters are as following: (int x, int y), where x, y is a 2D position on the screen. */ | ||||
|     void (*cursor)(int, int); | ||||
|     /** Pointer to a routine to put a character in a specified position.\n | ||||
|      Parameters are as following: (int x, int y, unsigned char c),\n | ||||
|      *         where:  x, y  =  2D position on the screen\n | ||||
|      *                 c     =  ascii character*/ | ||||
|     void (*putc)(int, int, unsigned char); | ||||
|     /** Pointer to a routine to return a character in a specified position.\n | ||||
|      Parameters are as following: (int x, int y), where x, y is a 2D position on the screen. */ | ||||
|     unsigned char (*getc)(int, int); | ||||
|     /** Pointer to a routine to set the colors for the character in the specified position\n | ||||
|      Parameters are as following: (int x, int y, unsigned char color),\n | ||||
|      *         where:  x, y  =  2D position on the screen\n | ||||
|      *                 color =  index in 16 color palette for background (high nibble) and foreground (low nibble)*/ | ||||
|     void (*putcolor)(int, int, unsigned char); | ||||
|     /** Pointer to a routine to return the colors for the character in the specified position\n | ||||
|      Parameters are as following: (int x, int y, unsigned char c),\n | ||||
|      *         where:  x, y  =  2D position on the screen*/ | ||||
|     unsigned char (*getcolor)(int, int); | ||||
| } ConsoleScreen; | ||||
|  | ||||
|  | ||||
| typedef struct { | ||||
|     /**Integer coordonates*/ | ||||
|     int X, Y; | ||||
| } Point; | ||||
|  | ||||
| typedef struct { | ||||
|     /**Unsigned integer coordonates.*/ | ||||
|     unsigned X, Y; | ||||
| } UPoint; | ||||
|  | ||||
| enum COLORS { | ||||
|     BLACK           = 0x0, | ||||
|     BLUE            = 0x1, | ||||
|     GREEN           = 0x2, | ||||
|     CYAN            = 0x3, | ||||
|     RED             = 0x4, | ||||
|     MAGENTA         = 0x5, | ||||
|     BROWN           = 0x6, | ||||
|     LIGHTGRAY       = 0x7, | ||||
|     DARKGRAY        = 0x8, | ||||
|     LIGHTBLUE       = 0x9, | ||||
|     LIGHTGREEN      = 0xA, | ||||
|     LIGHTCYAN       = 0xB, | ||||
|     LIGHTRED        = 0xC, | ||||
|     LIGHTMAGENTA    = 0xD, | ||||
|     YELLOW          = 0xE, | ||||
|     WHITE           = 0xF, | ||||
|     BLINK           = 0x80 | ||||
| }; | ||||
|  | ||||
| enum CURSORSHAPE { | ||||
|     _NOCURSOR       = 0x0, | ||||
|     _SOLIDCURSOR    = 0x1, | ||||
|     _NORMALCURSOR   = 0x2 | ||||
| }; | ||||
|  | ||||
| /***/ | ||||
| //extern char* cgets(char* string); | ||||
|  | ||||
|  | ||||
| extern void ConsoleInstall(ConsoleScreen screen); | ||||
| extern void ConsoleUpdateCursor(UPoint position, unsigned char type); | ||||
| extern void ConsoleScroll(unsigned lines); | ||||
|  | ||||
|  | ||||
| /** Clears to end of line in text window\n\n | ||||
|  Declaration:  void clreol(void);\n\n | ||||
|  Remarks:\n | ||||
| clreol clears all characters from the cursor position to the end of the line | ||||
|  within the current text window, without moving the cursor.\n\n | ||||
|  Return Value:  None*/ | ||||
| extern void clreol(); | ||||
| extern void clrscr(); | ||||
| extern void scroll(int n); | ||||
| extern void prev_line(); | ||||
| extern void next_line(); | ||||
| extern void putc_pos_font(int x, int y, char c, unsigned char back, unsigned char fore); | ||||
| extern void putc_pos(int x, int y, char c); | ||||
| extern void putc_font(char c, unsigned char back, unsigned char fore); | ||||
| extern void putc(char c); | ||||
| extern void puts_pos_font(int x, int y, const char *str, unsigned char back, unsigned char fore); | ||||
| extern void puts_pos(int x, int y, const char *str); | ||||
| extern void puts(const char *str); | ||||
| extern void puts_font(const char *str, unsigned char back, unsigned char fore); | ||||
| extern void put_hex(unsigned int alpha); | ||||
| extern void put_hex_pos(int x, int y, unsigned int alpha); | ||||
| extern void put_bin (int x, int y, unsigned char xz); | ||||
|        | ||||
| extern int gettext (int left, int top, int right, int bottom, unsigned char* dest); | ||||
| extern void gotoxy (int x, int y); | ||||
| extern int cprintf(const char* str, ...); | ||||
| extern int cputs(const char* str); | ||||
| extern int cgets(char* string, int maxlen); | ||||
| extern int getch(); | ||||
| extern int getche(); | ||||
| extern void movetext(int left, int top, int right, int bottom, int destleft, int desttop); | ||||
| extern int putch(const char c); | ||||
| extern int puttext(int left, int top, int right, int bottom, unsigned char* src); | ||||
| extern void _setcursortype (int cursor); | ||||
| extern int wherex(); | ||||
| extern int wherey(); | ||||
|  | ||||
| #endif | ||||
| @@ -1,55 +1,31 @@ | ||||
| #ifndef __CTYPE_H | ||||
| #define	__CTYPE_H | ||||
|  | ||||
| /****************************** | ||||
|  *    ctype.h                 * | ||||
|  *    - character macros      * | ||||
|  ******************************/ | ||||
| extern unsigned char _ctype[]; | ||||
|  | ||||
| #ifdef _MSC_VER | ||||
| // Get rid of conversion warnings | ||||
| #pragma warning (disable:4244) | ||||
| #endif | ||||
| #define _CTYPE_ISCONTROL    0x01  // 0000 0001 | ||||
| #define _CTYPE_ISSPACE      0x02  // 0000 0010 | ||||
| #define _CTYPE_ISBLANK      0x04  // 0000 0100 etc. | ||||
| #define _CTYPE_ISPUNCT      0x08 | ||||
| #define _CTYPE_ISDIGIT      0x10 | ||||
| #define _CTYPE_ISHEX        0x20 | ||||
| #define _CTYPE_ISUPPER        0x40 | ||||
| #define _CTYPE_ISLOWER        0x80 | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" | ||||
| { | ||||
| #endif | ||||
| #define isalnum(c) (_ctype[(int)c+1] & (_CTYPE_ISLOWER | _CTYPE_ISUPPER | _CTYPE_ISDIGIT)) | ||||
| #define isalpha(c) (_ctype[(int)c+1] & (_CTYPE_ISLOWER | _CTYPE_ISUPPER)) | ||||
| #define isblank(c) (_ctype[(int)c+1] & (_CTYPE_ISBLANK)) | ||||
| #define iscntrl(c) (_ctype[(int)c+1] & (_CTYPE_ISCONTROL)) | ||||
| #define isdigit(c) (_ctype[(int)c+1] & (_CTYPE_ISDIGIT)) | ||||
| #define isgraph(c) (_ctype[(int)c+1] & (_CTYPE_ISLOWER | _CTYPE_ISUPPER | _CTYPE_ISDIGIT | _CTYPE_ISPUNCT)) | ||||
| #define islower(c) (_ctype[(int)c+1] & (_CTYPE_ISLOWER)) | ||||
| #define isprint(c) (_ctype[(int)c+1] & (_CTYPE_ISLOWER | _CTYPE_ISUPPER | _CTYPE_ISDIGIT | _CTYPE_ISPUNCT | _CTYPE_ISBLANK)) | ||||
| #define ispunct(c) (_ctype[(int)c+1] & (_CTYPE_ISPUNCT)) | ||||
| #define isspace(c) (_ctype[(int)c+1] & (_CTYPE_ISSPACE)) | ||||
| #define isupper(c) (_ctype[(int)c+1] & (_CTYPE_ISUPPER)) | ||||
| #define isxdigit(c) (_ctype[(int)c+1] & (_CTYPE_ISHEX)) | ||||
|  | ||||
| extern char _ctype[]; | ||||
| extern int toupper(int c); | ||||
| extern int tolower(int c); | ||||
|  | ||||
| /* Constants */ | ||||
|  | ||||
| #define CT_UP	0x01	/* upper case */ | ||||
| #define CT_LOW	0x02	/* lower case */ | ||||
| #define CT_DIG	0x04	/* digit */ | ||||
| #define CT_CTL	0x08	/* control */ | ||||
| #define CT_PUN	0x10	/* punctuation */ | ||||
| #define CT_WHT	0x20	/* white space (space/cr/lf/tab) */ | ||||
| #define CT_HEX	0x40	/* hex digit */ | ||||
| #define CT_SP	0x80	/* hard space (0x20) */ | ||||
|  | ||||
| /* Basic macros */ | ||||
|  | ||||
| #define isalnum(c)	((_ctype + 1)[(unsigned)(c)] & (CT_UP | CT_LOW | CT_DIG)) | ||||
| #define isalpha(c)	((_ctype + 1)[(unsigned)(c)] & (CT_UP | CT_LOW)) | ||||
| #define iscntrl(c)	((_ctype + 1)[(unsigned)(c)] & (CT_CTL)) | ||||
| #define isdigit(c)	((_ctype + 1)[(unsigned)(c)] & (CT_DIG)) | ||||
| #define isgraph(c)	((_ctype + 1)[(unsigned)(c)] & (CT_PUN | CT_UP | CT_LOW | CT_DIG)) | ||||
| #define islower(c)	((_ctype + 1)[(unsigned)(c)] & (CT_LOW)) | ||||
| #define isprint(c)	((_ctype + 1)[(unsigned)(c)] & (CT_PUN | CT_UP | CT_LOW | CT_DIG | CT_SP)) | ||||
| #define ispunct(c)	((_ctype + 1)[(unsigned)(c)] & (CT_PUN)) | ||||
| #define isspace(c)	((_ctype + 1)[(unsigned)(c)] & (CT_WHT)) | ||||
| #define isupper(c)	((_ctype + 1)[(unsigned)(c)] & (CT_UP)) | ||||
| #define isxdigit(c)	((_ctype + 1)[(unsigned)(c)] & (CT_DIG | CT_HEX)) | ||||
| #define isascii(c)	((unsigned)(c) <= 0x7F) | ||||
| #define toascii(c)	((unsigned)(c) & 0x7F) | ||||
| #define tolower(c)	(isupper(c) ? c + 'a' - 'A' : c) | ||||
| #define toupper(c)	(islower(c) ? c + 'A' - 'a' : c) | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #endif | ||||
| #endif | ||||
| @@ -3,14 +3,15 @@ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <time.h> | ||||
| //#include <..\hal\floppy\floppy.h> | ||||
| #define far | ||||
| #define near | ||||
|  | ||||
| #define i86_start_interrupts() __asm__ __volatile__ ("sti"); | ||||
| #define i86_clear_interrupts() __asm__ __volatile__ ("cli"); | ||||
|  | ||||
| extern volatile TIME _internal_clock; | ||||
|  | ||||
| extern TIME i86_pit_get_time() ; | ||||
| extern unsigned* i86_read_sector (unsigned* where, unsigned char drive, int sectorLBA); | ||||
| // initialize hardware abstraction layer | ||||
| extern void i86_hal_initialize (); | ||||
|  | ||||
| @@ -23,10 +24,10 @@ extern int  i86_hal_shutdown (); | ||||
| //! output sound to speaker | ||||
| extern void sound (unsigned frequency); | ||||
|  | ||||
| //! read byte from device using port mapped io | ||||
| //! read unsigned char from device using port mapped io | ||||
| //extern unsigned char  inportb (unsigned short _port); | ||||
|  | ||||
| //! write byte to device through port mapped io | ||||
| //! write unsigned char to device through port mapped io | ||||
| //extern void  outportb (unsigned short _port, unsigned char _data); | ||||
|  | ||||
| //! sets new interrupt vector | ||||
| @@ -44,6 +45,7 @@ extern void reboot(); | ||||
| /********************************************************************** | ||||
|  *                  KEYBOARD STUFF                                    * | ||||
|  **********************************************************************/ | ||||
|  | ||||
| #define KB_KEY_LSHIFT 0x81    // 1000 0001 | ||||
| #define KB_KEY_RSHIFT 0X82    // 1000 0010 | ||||
| #define KB_KEY_LALT   0X84    // 1000 0100 | ||||
| @@ -51,130 +53,132 @@ extern void reboot(); | ||||
| #define KB_KEY_LCTRL  0x90    // 1001 0000 | ||||
| #define KB_KEY_RCTRL  0xA0    // 1010 0000 | ||||
| #define KB_KEY_FSHIFT 0xC0    // 1100 0000 | ||||
| extern volatile byte kb_modifier_status; | ||||
| extern volatile unsigned char kb_modifier_status; | ||||
|  | ||||
| #define KB_PREFIX_GRAY   0x01       // Gray | ||||
| #define KB_PREFIX_BREAK  0x02       // Break code | ||||
| #define KB_PREFIX_PAUSE  0x04       // Pause/break key | ||||
| #define KB_PREFIX_PAUSE1 0x08       // Recieved first byte from pause/break | ||||
| extern volatile byte kb_prefix; | ||||
| #define KB_PREFIX_PAUSE1 0x08       // Recieved first unsigned char from pause/break | ||||
| extern volatile unsigned char kb_prefix; | ||||
|  | ||||
| #define KB_KEY_SCROLL  0xF1   // 1111 0001 | ||||
| #define KB_KEY_NUM     0xF2   // 1111 0010 | ||||
| #define KB_KEY_CAPS    0xF4   // 1111 0100 | ||||
| extern volatile byte kb_lights_status; | ||||
| extern volatile unsigned char kb_lights_status; | ||||
|  | ||||
| extern byte kb_scancode_set; | ||||
| #define KB_KEY_PAUSE                0x00 | ||||
| #define KB_KEY_F9                   0x01 | ||||
| #define KB_KEY_F7                   0x02 | ||||
| #define KB_KEY_F5                   0X03 | ||||
| #define KB_KEY_F3                   0x04 | ||||
| #define KB_KEY_F1                   0x05 | ||||
| #define KB_KEY_F2                   0x06 | ||||
| #define KB_KEY_F12                  0x07 | ||||
| #define KB_KEY_PRINTSCRN            0x08 | ||||
| #define KB_KEY_F10                  0x09 | ||||
| #define KB_KEY_F8                   0x0A | ||||
| #define KB_KEY_F6                   0x0B | ||||
| #define KB_KEY_F4                   0x0C | ||||
| #define KB_KEY_TAB                  0x0D | ||||
| #define KB_KEY_TILDA                0x0E | ||||
| #define KB_KEY_Q                    0x15 | ||||
| #define KB_KEY_1                    0x16 | ||||
| #define KB_KEY_Z                    0x1A | ||||
| #define KB_KEY_S                    0x1B | ||||
| #define KB_KEY_A                    0x1C | ||||
| #define KB_KEY_W                    0x1D | ||||
| #define KB_KEY_2                    0x1E | ||||
| #define KB_KEY_LWIN                 0x1F | ||||
| #define KB_KEY_C                    0x21 | ||||
| #define KB_KEY_X                    0x22 | ||||
| #define KB_KEY_D                    0x23 | ||||
| #define KB_KEY_E                    0x24 | ||||
| #define KB_KEY_4                    0x25 | ||||
| #define KB_KEY_3                    0x26 | ||||
| #define KB_KEY_RWIN                 0x27 | ||||
| #define KB_KEY_SPACE                0x29 | ||||
| #define KB_KEY_V                    0x2A | ||||
| #define KB_KEY_F                    0x2B | ||||
| #define KB_KEY_T                    0x2C | ||||
| #define KB_KEY_R                    0x2D | ||||
| #define KB_KEY_5                    0x2E | ||||
| #define KB_KEY_MENU                 0x2F | ||||
| #define KB_KEY_N                    0x31 | ||||
| #define KB_KEY_B                    0x32 | ||||
| #define KB_KEY_H                    0x33 | ||||
| #define KB_KEY_G                    0x34 | ||||
| #define KB_KEY_Y                    0x35 | ||||
| #define KB_KEY_6                    0x36 | ||||
| #define KB_KEY_M                    0x3A | ||||
| #define KB_KEY_J                    0x3B | ||||
| #define KB_KEY_U                    0x3C | ||||
| #define KB_KEY_7                    0x3D | ||||
| #define KB_KEY_8                    0x3E | ||||
| #define KB_KEY_COMMA                0x41 | ||||
| #define KB_KEY_K                    0x42 | ||||
| #define KB_KEY_I                    0x43 | ||||
| #define KB_KEY_O                    0x44 | ||||
| #define KB_KEY_0                    0x45 | ||||
| #define KB_KEY_9                    0x46 | ||||
| #define KB_KEY_PERIOD               0x49 | ||||
| #define KB_KEY_SLASH                0x4A | ||||
| #define KB_KEY_L                    0x4B | ||||
| #define KB_KEY_SEMICOLON            0x4C | ||||
| #define KB_KEY_P                    0x4D | ||||
| #define KB_KEY_DASH                 0x4E | ||||
| #define KB_KEY_APOSTROPHE           0x52 | ||||
| #define KB_KEY_LBRACKET             0x54 | ||||
| #define KB_KEY_EQUAL                0x55 | ||||
| #define KB_KEY_NUMPAD_ENTER         0x59 | ||||
| #define KB_KEY_ENTER                0x5A | ||||
| #define KB_KEY_RBRACKET             0x5B | ||||
| #define KB_KEY_BACKSLASH            0x5D | ||||
| #define KB_KEY_END                  0x5E | ||||
| #define KB_KEY_LEFT                 0x5F | ||||
| #define KB_KEY_HOME                 0x60 | ||||
| #define KB_KEY_INSERT               0x61 | ||||
| #define KB_KEY_DELETE               0x62 | ||||
| #define KB_KEY_DOWN                 0x63 | ||||
| #define KB_KEY_RIGHT                0x64 | ||||
| #define KB_KEY_UP                   0x65 | ||||
| #define KB_KEY_BACKSPACE            0x66 | ||||
| #define KB_KEY_PGDOWN               0x67 | ||||
| #define KB_KEY_PGUP                 0x68 | ||||
| #define KB_KEY_NUMPAD_1             0x69 | ||||
| #define KB_KEY_NUMPAD_SLASH         0x6A | ||||
| #define KB_KEY_NUMPAD_4             0x6B | ||||
| #define KB_KEY_NUMPAD_7             0x6C | ||||
| #define KB_KEY_NUMPAD_0             0x70 | ||||
| #define KB_KEY_NUMPAD_COLON         0x71 | ||||
| #define KB_KEY_NUMPAD_2             0x72 | ||||
| #define KB_KEY_NUMPAD_5             0x73 | ||||
| #define KB_KEY_NUMPAD_6             0x74 | ||||
| #define KB_KEY_NUMPAD_8             0x75 | ||||
| #define KB_KEY_ESC                  0x76 | ||||
| #define KB_KEY_F11                  0x78 | ||||
| #define KB_KEY_NUMPAD_PLUS          0x79 | ||||
| #define KB_KEY_NUMPAD_3             0x7A | ||||
| #define KB_KEY_NUMPAD_MINUS         0x7B | ||||
| #define KB_KEY_NUMPAD_ASTERISK      0x7C | ||||
| #define KB_KEY_NUMPAD_9             0x7D | ||||
| extern unsigned char kb_scancode_set; | ||||
|  | ||||
| enum KB_KEYS { | ||||
|        KB_KEY_PAUSE         =      0x00, | ||||
|        KB_KEY_F9            =      0x01, | ||||
|        KB_KEY_F7            =      0x02, | ||||
|        KB_KEY_F5            =      0X03, | ||||
|        KB_KEY_F3            =      0x04, | ||||
|        KB_KEY_F1            =      0x05, | ||||
|        KB_KEY_F2            =      0x06, | ||||
|        KB_KEY_F12           =      0x07, | ||||
|        KB_KEY_PRINTSCRN     =      0x08, | ||||
|        KB_KEY_F10           =      0x09, | ||||
|        KB_KEY_F8            =      0x0A, | ||||
|        KB_KEY_F6            =      0x0B, | ||||
|        KB_KEY_F4            =      0x0C, | ||||
|        KB_KEY_TAB           =      0x0D, | ||||
|        KB_KEY_TILDA         =      0x0E, | ||||
|        KB_KEY_Q             =      0x15, | ||||
|        KB_KEY_1             =      0x16, | ||||
|        KB_KEY_Z             =      0x1A, | ||||
|        KB_KEY_S             =      0x1B, | ||||
|        KB_KEY_A             =      0x1C, | ||||
|        KB_KEY_W             =      0x1D, | ||||
|        KB_KEY_2             =      0x1E, | ||||
|        KB_KEY_LWIN          =      0x1F, | ||||
|        KB_KEY_C             =      0x21, | ||||
|        KB_KEY_X             =      0x22, | ||||
|        KB_KEY_D             =      0x23, | ||||
|        KB_KEY_E             =      0x24, | ||||
|        KB_KEY_4             =      0x25, | ||||
|        KB_KEY_3             =      0x26, | ||||
|        KB_KEY_RWIN          =      0x27, | ||||
|        KB_KEY_SPACE         =      0x29, | ||||
|        KB_KEY_V             =      0x2A, | ||||
|        KB_KEY_F             =      0x2B, | ||||
|        KB_KEY_T             =      0x2C, | ||||
|        KB_KEY_R             =      0x2D, | ||||
|        KB_KEY_5             =      0x2E, | ||||
|        KB_KEY_MENU          =      0x2F, | ||||
|        KB_KEY_N             =      0x31, | ||||
|        KB_KEY_B             =      0x32, | ||||
|        KB_KEY_H             =      0x33, | ||||
|        KB_KEY_G             =      0x34, | ||||
|        KB_KEY_Y             =      0x35, | ||||
|        KB_KEY_6             =      0x36, | ||||
|        KB_KEY_M             =      0x3A, | ||||
|        KB_KEY_J             =      0x3B, | ||||
|        KB_KEY_U             =      0x3C, | ||||
|        KB_KEY_7             =      0x3D, | ||||
|        KB_KEY_8             =      0x3E, | ||||
|        KB_KEY_COMMA         =      0x41, | ||||
|        KB_KEY_K             =      0x42, | ||||
|        KB_KEY_I             =      0x43, | ||||
|        KB_KEY_O             =      0x44, | ||||
|        KB_KEY_0             =      0x45, | ||||
|        KB_KEY_9             =      0x46, | ||||
|        KB_KEY_PERIOD        =      0x49, | ||||
|        KB_KEY_SLASH         =      0x4A, | ||||
|        KB_KEY_L             =      0x4B, | ||||
|        KB_KEY_SEMICOLON     =      0x4C, | ||||
|        KB_KEY_P             =      0x4D, | ||||
|        KB_KEY_DASH          =      0x4E, | ||||
|        KB_KEY_APOSTROPHE    =      0x52, | ||||
|        KB_KEY_LBRACKET      =      0x54, | ||||
|        KB_KEY_EQUAL         =      0x55, | ||||
|        KB_KEY_NUMPAD_ENTER  =      0x59, | ||||
|        KB_KEY_ENTER         =      0x5A, | ||||
|        KB_KEY_RBRACKET      =      0x5B, | ||||
|        KB_KEY_BACKSLASH     =      0x5D, | ||||
|        KB_KEY_END           =      0x5E, | ||||
|        KB_KEY_LEFT          =      0x5F, | ||||
|        KB_KEY_HOME          =      0x60, | ||||
|        KB_KEY_INSERT        =      0x61, | ||||
|        KB_KEY_DELETE        =      0x62, | ||||
|        KB_KEY_DOWN          =      0x63, | ||||
|        KB_KEY_RIGHT         =      0x64, | ||||
|        KB_KEY_UP            =      0x65, | ||||
|        KB_KEY_BACKSPACE     =      0x66, | ||||
|        KB_KEY_PGDOWN        =      0x67, | ||||
|        KB_KEY_PGUP          =      0x68, | ||||
|        KB_KEY_NUMPAD_1      =      0x69, | ||||
|        KB_KEY_NUMPAD_SLASH  =      0x6A, | ||||
|        KB_KEY_NUMPAD_4      =      0x6B, | ||||
|        KB_KEY_NUMPAD_7      =      0x6C, | ||||
|        KB_KEY_NUMPAD_0      =      0x70, | ||||
|        KB_KEY_NUMPAD_COLON  =      0x71, | ||||
|        KB_KEY_NUMPAD_2      =      0x72, | ||||
|        KB_KEY_NUMPAD_5      =      0x73, | ||||
|        KB_KEY_NUMPAD_6      =      0x74, | ||||
|        KB_KEY_NUMPAD_8      =      0x75, | ||||
|        KB_KEY_ESC           =      0x76, | ||||
|        KB_KEY_F11           =      0x78, | ||||
|        KB_KEY_NUMPAD_PLUS   =      0x79, | ||||
|        KB_KEY_NUMPAD_3      =      0x7A, | ||||
|        KB_KEY_NUMPAD_MINUS  =      0x7B, | ||||
|        KB_KEY_NUMPAD_ASTERISK =    0x7C, | ||||
|        KB_KEY_NUMPAD_9      =      0x7D | ||||
| }; | ||||
|        | ||||
| typedef struct { | ||||
|       byte status; | ||||
|       byte lights; | ||||
|       byte scancode; | ||||
|       byte character; | ||||
|       unsigned char status; | ||||
|       unsigned char lights; | ||||
|       unsigned char scancode; | ||||
|       unsigned char character; | ||||
| } kb_key; | ||||
|  | ||||
|  | ||||
| extern char getch(); | ||||
| //extern char getch(); | ||||
| extern kb_key getkey(); | ||||
| extern char scancode_to_ascii(byte scancode, byte status); | ||||
| extern byte get_key_status(byte scancode); | ||||
| extern char scancode_to_ascii(unsigned char scancode, unsigned char status); | ||||
| extern unsigned char get_key_status(unsigned char scancode); | ||||
| extern void kb_set_repeat(float rate, int delay); | ||||
| extern void kb_set_LEDs(byte status); | ||||
| extern void kb_set_LEDs(unsigned char status); | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										93
									
								
								SysCore/include/stdlib.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								SysCore/include/stdlib.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,93 @@ | ||||
| #ifndef __STDLIB_H__ | ||||
| #define __STDLIB_H__ | ||||
|  | ||||
| /** Returns the absolute value of an integer.*/ | ||||
| #define abs(x) (x>0) ? (x) : (x*-1) | ||||
| /** Returns the absolute value of a long variable.*/ | ||||
| #define labs(x) (x>0) ? (x) : (x*-1) | ||||
| /** Returns the maximum of two numbers.*/ | ||||
| #define max(a, b) (a > b) ? a : b | ||||
| /** Returns the minimum of two numbers.*/ | ||||
| #define min(a, b) (a < b) ? a : b | ||||
| #define NULL 0 | ||||
|  | ||||
| /** div_t is a structure of integers used by div()\n | ||||
|  Notes:\n | ||||
|  - quot = quotient;\n | ||||
|  - rem  = remainder;\n */ | ||||
| typedef struct { | ||||
|     /** Quotient */ | ||||
|     long quot; | ||||
|     /** Remainder */ | ||||
|     long rem; | ||||
| } div_t; | ||||
|  | ||||
| /** ldiv_t is a structure of integers used by ldiv()\n | ||||
|  Notes:\n | ||||
|  - quot = quotient;\n | ||||
|  - rem  = remainder;\n */ | ||||
| typedef struct { | ||||
|     /** Quotient*/ | ||||
|     long quot; | ||||
|     /** Remainder*/ | ||||
|     long rem; | ||||
| } ldiv_t; | ||||
|  | ||||
|  | ||||
| // TODO: extern long double _atold (const char* string); | ||||
| // TODO: extern double atof (const char* string);      // TODO: initialize FPU | ||||
|  | ||||
| /** Convert ASCII string to INT */ | ||||
| extern int      atoi    (const char* string); | ||||
|  | ||||
| /** Convert ASCII string to LONG */ | ||||
| extern long     atol    (const char* string); | ||||
|  | ||||
| /** Convert ASCII string in hexadecimal to unsigned integer.*/ | ||||
| extern unsigned int atox (const char* string); | ||||
|  | ||||
| /** Peform a binary search\n | ||||
|  Notes:\n | ||||
|  - const void*  key     =   A pointer to the element to look for\n | ||||
|  - const void*  base    =   A pointer to the first element of the table\n | ||||
|  - unsigned     nelem   =   The number of elements in the table\n | ||||
|  - unsigned     width   =   The size of one element of the table\n | ||||
|  - int          *fcmp   =   A user defined comparison routine\n */ | ||||
| extern void*    bsearch (const void* key, const void* base, unsigned nelem, unsigned width, int (*fcmp)(const void*, const void*)); | ||||
|  | ||||
| /**Divides two integers and returns both the quotient and the remainder as a div_t structure.*/ | ||||
| extern div_t    div     (int numerator, int denominator); | ||||
|  | ||||
| /** Convert SIGNED INT to ASCII string */ | ||||
| extern void     itoa    (signed int value, char *string, int radix); | ||||
|  | ||||
| /**Divides two longs and returns both the quotient and the remainder as a ldiv_t structure.*/ | ||||
| extern ldiv_t   ldiv    (long numerator, long denominator); | ||||
|  | ||||
| /**Does a linear search for *key in a table\n | ||||
|  Notes:\n | ||||
|  - const void*  key     =   A pointer to the element to look for\n | ||||
|  - const void*  base    =   A pointer to the first element of the table\n | ||||
|  - unsigned     nelem   =   The number of elements in the table\n | ||||
|  - unsigned     width   =   The size of one element of the table\n | ||||
|  - int          *fcmp   =   A user defined comparison routine\n */ | ||||
| void* lfind (const void* key, const void* base, unsigned nelem, unsigned width, int (*fcmp)(const void*, const void*)); | ||||
|  | ||||
| /** Convert SIGNED LONG to ASCII string */ | ||||
| extern void     ltoa    (signed long value, char *string, int radix); | ||||
|  | ||||
| /** Sorts an array using an optimized quick sort algorithm.\n | ||||
|  Notes:\n | ||||
|  - void         base    =   A pointer to the first element of the table\n | ||||
|  - unsigned     *nelem   =   The number of elements in the table\n | ||||
|  - unsigned     width   =   The size of one element of the table\n | ||||
|  - int          *fcmp   =   A user defined comparison routine\n */ | ||||
| void qsort (void* base, unsigned nelem, unsigned width, int (*fcmp)(const void*, const void*)); | ||||
|  | ||||
| /** Convert UNSIGNED INT to ASCII string */ | ||||
| extern void     uitoa   (unsigned int value, char *string, int radix); | ||||
|  | ||||
| /** Convert UNSIGNED LONG to ASCII string */ | ||||
| extern void     ultoa   (unsigned long value, char *string, int radix); | ||||
|  | ||||
| #endif | ||||
| @@ -1,21 +1,19 @@ | ||||
| #ifndef __TIME_C | ||||
| #define __TIME_C | ||||
|  | ||||
| extern const char* clock_months[13]; | ||||
| extern const char* clock_weekdays[8]; | ||||
| extern byte clock_months_len[13]; | ||||
| extern const char* clock_month[13]; | ||||
| extern const char* clock_weekday[8]; | ||||
| extern unsigned char clock_month_len[13]; | ||||
|  | ||||
| typedef struct { | ||||
|       byte seconds; | ||||
|       byte minutes; | ||||
|       byte hours; | ||||
|       byte weekday; | ||||
|       byte day; | ||||
|       byte month; | ||||
|       byte year; | ||||
|       byte century; | ||||
|       byte am_pm; | ||||
|        | ||||
|       unsigned char second; | ||||
|       unsigned char minute; | ||||
|       unsigned char hour; | ||||
|       unsigned char weekday; | ||||
|       unsigned char day; | ||||
|       unsigned char month; | ||||
|       unsigned char year; | ||||
|       unsigned char century; | ||||
| } TIME; | ||||
|  | ||||
| extern void _CLOCK_INC(TIME *tim); | ||||
|   | ||||
| @@ -11,7 +11,9 @@ set incpath=../include | ||||
| del %objpath%\system.o | ||||
| del %objpath%\string.o | ||||
| del %objpath%\conio.o | ||||
| del %objpath%\stdlib.o | ||||
| del %objpath%\time.o | ||||
| del %objpath%\ctype.o | ||||
|  | ||||
| goto build | ||||
| :error | ||||
| @@ -30,6 +32,13 @@ goto build | ||||
|       @echo       * Compiling CONIO.C ... | ||||
|       %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/conio.o conio.c  | ||||
|  | ||||
|       @echo       * Compiling CTYPE.C ... | ||||
|       %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/ctype.o ctype.c  | ||||
|  | ||||
|  | ||||
|       @echo       * Compiling STDLIB.C ... | ||||
|       %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/stdlib.o stdlib.c | ||||
|  | ||||
|       @echo       * Compiling TIME.C ... | ||||
|       %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/time.o time.c  | ||||
|  | ||||
| @@ -37,4 +46,6 @@ goto build | ||||
|       if not exist %objpath%\system.o goto error | ||||
|       if not exist %objpath%\string.o goto error | ||||
|       if not exist %objpath%\conio.o goto error | ||||
|       if not exist %objpath%\ctype.o goto error | ||||
|       if not exist %objpath%\stdlib.o goto error | ||||
|       if not exist %objpath%\time.o goto error | ||||
|   | ||||
| @@ -1,34 +1,530 @@ | ||||
| #include <stdarg.h> | ||||
| #include <stdint.h> | ||||
| #include <string.h> | ||||
| #include <system.h> | ||||
| #include <conio.h> | ||||
| #include <hal.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include <ctype.h> | ||||
| #include "../memory/mmngr_ph.h" | ||||
|  | ||||
| byte default_background, default_foreground; | ||||
| unsigned char ColorDefault; | ||||
| unsigned char ConsoleScreenInstalled = 0; | ||||
| /*char hex[] = "0123456789ABCDEF"; */ | ||||
|  | ||||
| char hex[] = "0123456789ABCDEF"; | ||||
| const static char base_chars[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"; | ||||
| /* External routines the user must specify */ | ||||
| void          (*_console_cursor)(int x, int y); | ||||
| void          (*_console_putc)(int x, int y, unsigned char c); | ||||
| unsigned char (*_console_getc) (int x, int y); | ||||
| void          (*_console_putcolor)(int x, int y, unsigned char color); | ||||
| unsigned char (*_console_getcolor)(int x, int y); | ||||
|  | ||||
| int abs(int x) | ||||
| /* Other external routines */ | ||||
| extern void *memset(void *dest, char val, int count); | ||||
|  | ||||
| /* Important variables */ | ||||
| UPoint ScreenSize, Cursor; | ||||
|  | ||||
| void ConsoleInstall(ConsoleScreen screen) | ||||
| { | ||||
|       return (x>0) ? (x) : (x*-1); | ||||
|     _console_cursor = screen.cursor; | ||||
|     _console_putc = screen.putc; | ||||
|     _console_getc = screen.getc; | ||||
|  | ||||
|     _console_putcolor = screen.putcolor; | ||||
|     _console_getcolor = screen.getcolor; | ||||
|  | ||||
|     ScreenSize.X = screen.width; | ||||
|     ScreenSize.Y = screen.height; | ||||
|  | ||||
|     ColorDefault = screen.defcolors; | ||||
|  | ||||
|     Cursor.X = 0; Cursor.Y = 0; | ||||
|     ConsoleUpdateCursor (Cursor, _NORMALCURSOR); | ||||
|  | ||||
|     ConsoleScreenInstalled = 1; | ||||
|  | ||||
| } | ||||
|  | ||||
| unsigned char _cuc_ex_type; | ||||
| UPoint _cuc_ex_pos; | ||||
| void ConsoleUpdateCursor(UPoint position, unsigned char type) | ||||
| { | ||||
|     if (_cuc_ex_type == _SOLIDCURSOR) | ||||
|         (*_console_putcolor) ( | ||||
|             _cuc_ex_pos.X, | ||||
|             _cuc_ex_pos.Y, | ||||
|             0xFF - (*_console_getcolor)(_cuc_ex_pos.X, _cuc_ex_pos.Y) | ||||
|             ); | ||||
|     if (_cuc_ex_type == _NORMALCURSOR && type != _NORMALCURSOR) | ||||
|         (*_console_cursor)(ScreenSize.X, ScreenSize.Y); | ||||
|      | ||||
|     switch (type) { | ||||
|         case _NORMALCURSOR: | ||||
|             (*_console_cursor)(position.X, position.Y); | ||||
|             break; | ||||
|         case _SOLIDCURSOR: | ||||
|             (*_console_putcolor) ( | ||||
|                 position.X, position.Y, | ||||
|                 0xFF - (*_console_getcolor)(position.X, position.Y) | ||||
|             ); break; | ||||
|         case _NOCURSOR: | ||||
|             (*_console_cursor)(ScreenSize.X, ScreenSize.Y); break; | ||||
|     } | ||||
|  | ||||
|     _cuc_ex_type = type; | ||||
|     _cuc_ex_pos.X = position.X; | ||||
|     _cuc_ex_pos.Y = position.Y; | ||||
| } | ||||
|  | ||||
|  | ||||
| void ConsoleScroll(unsigned lines) | ||||
| { | ||||
|     movetext(0, (int)lines, ScreenSize.X, ScreenSize.Y, 0, 0); | ||||
| } | ||||
|  | ||||
|  | ||||
| void ConsoleSetDefaultColors (unsigned char background, unsigned char foreground) | ||||
| { | ||||
|     ColorDefault = (foreground & 0xF) | (background<<4); | ||||
| } | ||||
|  | ||||
|  | ||||
| void ConsoleSetCursorPosition (Point rel, unsigned char display) | ||||
| { | ||||
|     Point abs = {  (int)(Cursor.X) + rel.X, | ||||
|                    (int)(Cursor.Y) + rel.Y  }; | ||||
|  | ||||
|     while (abs.X < 0)                   { abs.X += (int)ScreenSize.X; abs.Y--; } | ||||
|     while (abs.X >= (int)ScreenSize.X)  { abs.X -= (int)ScreenSize.X; abs.Y++; } | ||||
|     if    (abs.Y < 0)                   abs.Y = 0; | ||||
|  | ||||
|     if (abs.Y >= (int)ScreenSize.Y) { | ||||
|         ConsoleScroll((unsigned)abs.Y - ScreenSize.Y + 1); | ||||
|         abs.Y = (int)ScreenSize.Y - 1; | ||||
|     } | ||||
|  | ||||
|     Cursor.X = (unsigned)abs.X; | ||||
|     Cursor.Y = (unsigned)abs.Y; | ||||
|     if (display) ConsoleUpdateCursor(Cursor, _cuc_ex_type); | ||||
|      | ||||
| } | ||||
|  | ||||
| /**Inline function to return the index of next word\n | ||||
|  Parameters:\n | ||||
|     - const char* string    =   string to check for words\n | ||||
|     - int len               =   length of string\n | ||||
|     - int current           =   current cursor position\n | ||||
|     - int plus              =   direction (0:back, 1:foward)\n*/ | ||||
| inline int __cgets__skip_word(const char* string, int len, int current, int plus) | ||||
| { | ||||
|     int tmp = current; | ||||
|  | ||||
|     if (!plus) { | ||||
|         --tmp; | ||||
|         while ((isspace((unsigned char)string[tmp]) || ispunct((unsigned char)string[tmp])) && tmp > 0) --tmp; | ||||
|         while (isalnum((unsigned char)string[tmp]) && tmp > 0) --tmp; | ||||
|     } | ||||
|  | ||||
|     else { | ||||
|         ++tmp; | ||||
|         while (isalnum((unsigned char)string[tmp]) && tmp < len) ++tmp; | ||||
|         while ((isspace((unsigned char)string[tmp]) || ispunct((unsigned char)string[tmp])) && tmp < len) ++tmp; | ||||
|     } | ||||
|  | ||||
|     if (tmp != 0 && plus==0) tmp++; | ||||
|     return tmp; | ||||
| } | ||||
|  | ||||
| /**Macro which defines the INSERT key behaviour (overwrite/insert mode)*/ | ||||
| #define __cgets__key_insert() OverWrite = 1 - OverWrite | ||||
| /**Macro which defines the ENTER key behaviour*/ | ||||
| #define __cgets__key_enter() {  ConsoleSetCursorPosition((Point){Len, 0}, 1); return Len; } | ||||
|  | ||||
| /**Move the cursor to the left/right\n | ||||
|  Parameters:\n | ||||
|     - const char* string    =   the character string to work with\n | ||||
|     - int direction         =   direction to go (0: backward, 1:foward)\n | ||||
|     - int len               =   length of string\n | ||||
|     - int* cursor           =   pointer to cursor integer\n | ||||
|     - int word              =   move one word (1) or just one character(0)\n */ | ||||
| inline void __cgets__move_cursor(const char* string, int direction, int len, int* cursor, int word) | ||||
| { | ||||
|     int dtmp = (direction) ? 1 : -1; | ||||
|     if ((*cursor <= 0 && direction == 0) || (*cursor >= len && direction == 1)) return; | ||||
|  | ||||
|     // Skip one word (e.g. CTRL is pressed) | ||||
|     if (word) { | ||||
|         int tmp = __cgets__skip_word(string, len, *cursor+dtmp, direction); | ||||
|         *cursor = tmp; | ||||
|     } | ||||
|     else { | ||||
|         *cursor += dtmp; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /**Deletes the substring between index_start and index_end-1, also updates string length\n | ||||
|  Parameters:\n | ||||
|     - char* string          =   the character string to work with\n | ||||
|     - int index_start       =   where to start\n | ||||
|     - int index_end         =   where to stop\n | ||||
|     - int* len              =   pointer to length of string\n*/ | ||||
| inline void __cgets__delete (char* string, int index_start, int index_end, int* len) | ||||
| { | ||||
|     for (; index_end <= *len+1; index_start++, index_end++) | ||||
|             string[index_start] = string[index_end]; | ||||
|      | ||||
|     *len = strlen(string); | ||||
| } | ||||
|  | ||||
| /**Inserts a char in position of index, also updates string length\n | ||||
|  Parameters:\n | ||||
|     - char* string          =   the character string to work with\n | ||||
|     - int index             =   where to insert\n | ||||
|     - char c                =   characer to insert\n | ||||
|     - int* len              =   pointer to length of string\n*/ | ||||
| inline void __cgets__insert (char* string, int index, char c, int* len) | ||||
| { | ||||
|     *len = *len+1; | ||||
|     int i; | ||||
|  | ||||
|     for (i = *len-1; i > index; i--) | ||||
|         string[i] = string[i-1]; | ||||
|     string[index] = c; | ||||
|  | ||||
|     string[*len] = 0; | ||||
| } | ||||
|  | ||||
| int cgets(char* string, int maxlen) | ||||
| { | ||||
|     unsigned char OverWrite = 0; | ||||
|     memset ((void*)string, 0, maxlen); | ||||
|  | ||||
|     int Len = 0, CurPos = 0; | ||||
|     kb_key Key; | ||||
|     UPoint CursorSave; | ||||
|  | ||||
|     while (Len < maxlen) | ||||
|     { | ||||
|         // Display string on the screen | ||||
|         CursorSave = Cursor; | ||||
|         ConsoleUpdateCursor(Cursor, _NOCURSOR); | ||||
|         cputs(string); clreol(); | ||||
|         // Display cursor in right position | ||||
|         Cursor = CursorSave; | ||||
|         ConsoleSetCursorPosition((Point){CurPos, 0}, 0); | ||||
|         ConsoleUpdateCursor(Cursor, (OverWrite) ? _SOLIDCURSOR : _NORMALCURSOR); | ||||
|         // Restore cursor | ||||
|         Cursor = CursorSave; | ||||
|  | ||||
|         // Get key and process | ||||
|         Key = getkey(); | ||||
|  | ||||
|         switch (Key.scancode) { | ||||
|             // Switch overwrite/insert | ||||
|             case KB_KEY_INSERT: __cgets__key_insert(); break; | ||||
|  | ||||
|             // Finish writing (return) | ||||
|             case KB_KEY_ENTER: __cgets__key_enter(); break; | ||||
|             case KB_KEY_NUMPAD_ENTER: __cgets__key_enter(); break; | ||||
|  | ||||
|             // Left | ||||
|             case KB_KEY_LEFT: | ||||
|                 __cgets__move_cursor(string, 0, Len, &CurPos, ((Key.status & KB_KEY_LCTRL) || (Key.status & KB_KEY_RCTRL))); | ||||
|                 break; | ||||
|  | ||||
|             // Right | ||||
|             case KB_KEY_RIGHT: | ||||
|                 __cgets__move_cursor(string, 1, Len, &CurPos, ((Key.status & KB_KEY_LCTRL) || (Key.status & KB_KEY_RCTRL))); | ||||
|                 break; | ||||
|  | ||||
|             case KB_KEY_HOME: | ||||
|                 CurPos = 0; | ||||
|                 break; | ||||
|  | ||||
|             case KB_KEY_END: | ||||
|                 CurPos = Len; | ||||
|                 break; | ||||
|  | ||||
|             case KB_KEY_BACKSPACE: | ||||
|                 if (CurPos > 0) { | ||||
|                     int tmp; | ||||
|                     if ((Key.status & KB_KEY_LCTRL) || (Key.status & KB_KEY_RCTRL)) | ||||
|                         tmp = __cgets__skip_word(string, Len, CurPos, 0); | ||||
|                     else tmp = CurPos-1; | ||||
|                      | ||||
|                     __cgets__delete(string, tmp, CurPos, &Len); | ||||
|                     CurPos = tmp; | ||||
|                      | ||||
|                 }; | ||||
|                 break; | ||||
|  | ||||
|             // Delete | ||||
|             case KB_KEY_DELETE: | ||||
|                 if (CurPos < Len) { | ||||
|                     int tmp; | ||||
|                     // If CTRL is pressed, foward one word | ||||
|                     if ((Key.status & KB_KEY_LCTRL) || (Key.status & KB_KEY_RCTRL)) | ||||
|                         tmp = __cgets__skip_word(string, Len, CurPos, 1); | ||||
|                     else tmp = CurPos+1; | ||||
|                      | ||||
|                     __cgets__delete(string, CurPos, tmp, &Len); | ||||
|  | ||||
|  | ||||
|                 } | ||||
|                 break; | ||||
|  | ||||
|             // Text character | ||||
|             default: | ||||
|                 if (isprint(Key.character)) { | ||||
|                     // fix CAPS bug | ||||
|                     if ((Key.lights & KB_KEY_CAPS) && islower((unsigned char)Key.character)) | ||||
|                         Key.character = toupper(Key.character); | ||||
|  | ||||
|                     // Cursor is at the end of the string | ||||
|                     if (CurPos == Len) { | ||||
|                         Len++; string[Len-1] = Key.character; | ||||
|                         string[Len] = 0; | ||||
|                     } | ||||
|  | ||||
|                     // Cursor is not at the end in OverWrite mode | ||||
|                     else if (OverWrite) string[CurPos] = Key.character; | ||||
|  | ||||
|                     // Cursor is not at the end in Insert mode | ||||
|                     else __cgets__insert(string, CurPos, Key.character, &Len); | ||||
|  | ||||
|                     // Increase cursor position | ||||
|                     CurPos++; | ||||
|                 } | ||||
|                 break; | ||||
|         } | ||||
|  | ||||
|     } | ||||
|      | ||||
|     __cgets__key_enter(); | ||||
| } | ||||
|  | ||||
|  | ||||
| void clreol() | ||||
| { | ||||
|     int counter = Cursor.X; | ||||
|     while (counter < ScreenSize.X) { | ||||
|         (*_console_putc)(counter, Cursor.Y, 0); | ||||
|         ++counter; | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| void clrscr() | ||||
| { | ||||
|     for (Cursor.Y = 0; Cursor.Y < ScreenSize.Y; Cursor.Y++) | ||||
|         for (Cursor.X = 0; Cursor.X < ScreenSize.X; Cursor.X++) { | ||||
|             _console_putc(Cursor.X, Cursor.Y, 0); | ||||
|             _console_putcolor(Cursor.X, Cursor.Y, ColorDefault); | ||||
|         } | ||||
|     Cursor.X = 0; Cursor.Y = 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| void getpass (char* string) | ||||
| {} | ||||
|  | ||||
|  | ||||
| int gettext (int left, int top, int right, int bottom, unsigned char* dest) | ||||
| { | ||||
|     if (left < 0 || top < 0 || (unsigned)right > ScreenSize.X || (unsigned)bottom > ScreenSize.Y) | ||||
|         return 0; | ||||
|  | ||||
|     int i, j; | ||||
|  | ||||
|     for (i = top; i < bottom; i++) | ||||
|         for (j = left; j < right; j++) { | ||||
|             *dest++ = (*_console_getc)(j, i); | ||||
|             *dest++ = (*_console_getcolor)(j, i); | ||||
|         } | ||||
|     return 1; | ||||
| } | ||||
|  | ||||
|  | ||||
| void gotoxy (int x, int y) | ||||
| { | ||||
|     Cursor.X = x; Cursor.Y = y; | ||||
|     ConsoleUpdateCursor(Cursor, _cuc_ex_type); | ||||
| } | ||||
|  | ||||
| int cputs(const char* str) | ||||
| { | ||||
|     while (*str != 0) { | ||||
|         putch(*str); str++; | ||||
|     } | ||||
|     return (int)*str; | ||||
| } | ||||
|  | ||||
|  | ||||
| int getch() | ||||
| { | ||||
|     kb_key k; | ||||
|     k = getkey(); | ||||
|      | ||||
|     if ((k.lights & KB_KEY_CAPS) && k.character >= 'a' && k.character <= 'z') | ||||
|         return (int)(k.character - 'a' + 'A'); | ||||
|  | ||||
|     return k.character; | ||||
| } | ||||
|  | ||||
|  | ||||
| int getche() | ||||
| { | ||||
|     int ret = getch(); | ||||
|     putch((char)ret); | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*TODO: kbhit()*/ | ||||
| void movetext(int left, int top, int right, int bottom, int destleft, int desttop) | ||||
| { | ||||
|     int destright = destleft + right - left; | ||||
|     int destbottom = desttop + bottom - top; | ||||
|     // Sanity check | ||||
|     if (left < 0 || top < 0 || (unsigned)right > ScreenSize.X || | ||||
|       (unsigned)bottom > ScreenSize.Y || destleft < 0 || desttop < 0) | ||||
|         return; | ||||
|  | ||||
|     // Allocate memory | ||||
|     int needed_mem = ((right-left) * (bottom - top) * 2) / pmmngr_get_block_size(); | ||||
|     unsigned char* map = (unsigned char*) pmmngr_alloc_blocks(needed_mem); | ||||
|  | ||||
|     // Save box in a buffer | ||||
|     gettext(left, top, right, bottom, map); | ||||
|  | ||||
|     // Empty box | ||||
|     int i, j; | ||||
|     for (i = top; i < bottom; i++) | ||||
|         for (j = left; j < right; j++) { | ||||
|             (*_console_putc)(j, i, 0); | ||||
|             (*_console_putcolor)(j, i, ColorDefault); | ||||
|         } | ||||
|     // Put new text | ||||
|     puttext(destleft, desttop, destright, destbottom, map); | ||||
|  | ||||
|     // Free used memory | ||||
|     pmmngr_free_blocks((unsigned)map, needed_mem * pmmngr_get_block_size()); | ||||
| } | ||||
|  | ||||
| int putch(const char c) | ||||
| { | ||||
|     switch(c) | ||||
|     { | ||||
|         case '\n': ConsoleSetCursorPosition((Point){0, 1}, 0); | ||||
|                    break; | ||||
|  | ||||
|         case '\r': Cursor.X = 0; | ||||
|                    break; | ||||
|  | ||||
|         case '\t': ConsoleSetCursorPosition((Point){6 - (Cursor.X % 6), 0}, 0); | ||||
|                    break; | ||||
|  | ||||
|         case '\b': ConsoleSetCursorPosition((Point){-1, 0}, 0); | ||||
|                    (*_console_putc)(Cursor.X, Cursor.Y, 0); | ||||
|                    break; | ||||
|                     | ||||
|         default: | ||||
|             (*_console_putc)(Cursor.X, Cursor.Y, c); | ||||
|             (*_console_putcolor)(Cursor.X, Cursor.Y, ColorDefault); | ||||
|             ConsoleSetCursorPosition((Point){1,0}, 0); | ||||
|             break; | ||||
|     } | ||||
|  | ||||
|     return c; | ||||
| } | ||||
|  | ||||
| int puttext(int left, int top, int right, int bottom, unsigned char* src) | ||||
| { | ||||
|     if (left < 0 || top < 0 || (unsigned)right > ScreenSize.X || (unsigned)bottom > ScreenSize.Y) | ||||
|         return 0; | ||||
|     int i,j; | ||||
|     for (i = top; i < bottom; i++) | ||||
|         for (j = left; j < right; j++) { | ||||
|             (*_console_putc)(j, i, *src++); | ||||
|             (*_console_putcolor)(j, i, *src++); | ||||
|         } | ||||
|     return 1; | ||||
| } | ||||
|  | ||||
| void _setcursortype (int cursor) | ||||
| { | ||||
|     ConsoleUpdateCursor(Cursor, cursor); | ||||
| } | ||||
|  | ||||
| int wherex() { return (int)Cursor.X; }; | ||||
| int wherey() { return (int)Cursor.Y; }; | ||||
|  | ||||
|  | ||||
| int cprintf(const char* str, ...) | ||||
| { | ||||
|     if (!ConsoleScreenInstalled) return -1; | ||||
|       if (!str || !*str) return 0; | ||||
|  | ||||
|       va_list args; | ||||
|       va_start (args, str); | ||||
|       unsigned i, len = strlen(str); | ||||
|       unsigned char temp_col = ColorDefault; | ||||
|  | ||||
|       for (i = 0; i < len; i++) | ||||
|             switch (str[i]) { | ||||
|               case '%': | ||||
|                   switch (str[i+1]) { | ||||
|                      // Character | ||||
|                      case 'c':   {char c = va_arg (args, char); | ||||
|                                   putch(c); i++; break;} | ||||
|                      // String | ||||
|                      case 's':   {int* c = (int*) va_arg (args, char*); | ||||
|                                   cputs((const char*)c); i++; break;} | ||||
|                      // Integers | ||||
|                      case 'd': | ||||
|                      case 'i':   {int c = va_arg(args, int); | ||||
|                                   char temp[32]; | ||||
|                                   itoa(c, temp, 10); | ||||
|                                   cputs(temp); | ||||
|                                   i++; break;} | ||||
|                      // Integers - hex | ||||
|                      case 'X': | ||||
|                      case 'x':   {int c = va_arg(args, int); | ||||
|                                   char temp[32]; | ||||
|                                   uitoa(c, temp, 16); | ||||
|                                   cputs(temp); | ||||
|                                   i++; break;} | ||||
|  | ||||
|                      // Integers - unsigned | ||||
|                      case 'u': { int c = va_arg(args, unsigned int); | ||||
|                                   char temp[32]; | ||||
|                                   uitoa(c, temp, 10); | ||||
|                                   cputs(temp); | ||||
|                                   i++; break; | ||||
|                                   } | ||||
|  | ||||
|                      case '#': { char temp[] = {str[i+2], str[i+3], 0}; | ||||
|                                 ColorDefault = (unsigned char) atox(temp); | ||||
|                                 i+=3; | ||||
|                                 break; } | ||||
|                       | ||||
|  | ||||
|                      default: va_end(args); return 1; | ||||
|                   }; | ||||
|                break; | ||||
|                default: putch(str[i]); break; | ||||
|             } | ||||
|  | ||||
|       va_end(args); | ||||
|       ColorDefault = temp_col; | ||||
|       return i; | ||||
| } | ||||
|  | ||||
| /* | ||||
| void graphics_init() | ||||
| { | ||||
|   // Detect if color/monochrome screen | ||||
| 	char c = (*(volatile unsigned short*)0x410)&0x30; | ||||
| 	if (c==0x30) TextVideoRam = (byte *)0xb0000; | ||||
| 	else TextVideoRam = (byte *)0xb8000; | ||||
| 	 | ||||
|   // Reset cursor, use 80x25 text video mode | ||||
|       current_mode_width = 80; | ||||
|       current_mode_height = 25; | ||||
|       cursor_x = cursor_y = 0; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| // Change cursor position | ||||
| void text_mode_cursor(int x, int y) | ||||
| { | ||||
| @@ -41,17 +537,17 @@ void text_mode_cursor(int x, int y) | ||||
| } | ||||
|  | ||||
| // Set the default colors; max is 0x0F | ||||
| void set_default_colors(byte back, byte fore) | ||||
| void set_default_colors(unsigned char back, unsigned char fore) | ||||
| { | ||||
|       if (back < 0x10) default_background = back; | ||||
|       if (fore < 0x10) default_foreground = fore; | ||||
|       if (back < 0x10) ColorDefaultBack = back; | ||||
|       if (fore < 0x10) ColorDefaultFore = fore; | ||||
| } | ||||
|  | ||||
|  | ||||
| // Clear screen, and set font to default font | ||||
| void clrscr() | ||||
| { | ||||
|       byte font = default_foreground | (default_background<<4); | ||||
|       unsigned char font = ColorDefaultFore | (ColorDefaultBack<<4); | ||||
|       int i = 0; | ||||
|       for (i = 0; i < current_mode_width*current_mode_height; i++) | ||||
|       {     TextVideoRam[2*i] = 0; | ||||
| @@ -66,7 +562,7 @@ void scroll(int n) | ||||
|              TextVideoRam+(current_mode_width*n*2), | ||||
|              2*current_mode_width*(current_mode_height - n)); | ||||
|               | ||||
|       byte blank = default_foreground | (default_background<<4); | ||||
|       unsigned char blank = ColorDefaultFore | (ColorDefaultBack<<4); | ||||
|        | ||||
|       int i; | ||||
|       for (i = current_mode_width*(current_mode_height-n); | ||||
| @@ -95,7 +591,7 @@ void next_line() | ||||
|  | ||||
|  | ||||
| // Put character on screen in specified position; can use different font colors | ||||
| void putc_pos_font(int x, int y, char c, byte back, byte fore) | ||||
| void putc_pos_font(int x, int y, char c, unsigned char back, unsigned char fore) | ||||
| { | ||||
| 	TextVideoRam[2*(y*current_mode_width+x)] = c; | ||||
| 	TextVideoRam[2*(y*current_mode_width+x)+1] = fore|(back<<4); | ||||
| @@ -106,7 +602,7 @@ void putc_pos(int x, int y, char c) | ||||
| 	TextVideoRam[2*(y*current_mode_width+x)] = c; | ||||
| } | ||||
| // Put character on screen in the current cursor position; different font colors | ||||
| void putc_font(char c, byte back, byte fore) | ||||
| void putc_font(char c, unsigned char back, unsigned char fore) | ||||
| { | ||||
|       if (cursor_x >= current_mode_width) next_line(); | ||||
|        | ||||
| @@ -126,50 +622,11 @@ void putc(char c) | ||||
|       cursor_x++; | ||||
| } | ||||
|  | ||||
| // Unsigned INT to ASCII | ||||
| void uitoa (unsigned int value, char *string, int radix) | ||||
| { | ||||
|       if (radix == 1 || radix>36) return; | ||||
|        | ||||
|       // Calculate how much space needed for number | ||||
|       int len, temp = abs(value); | ||||
|       for (len = 0; temp > 0; len++) temp/=radix; | ||||
|       if (len == 0) len = 1; | ||||
|        | ||||
|       string[len] = 0; | ||||
|       for (len--; len >=0; len-- ) { | ||||
|             string[len] = base_chars[value%radix]; | ||||
|             value/=radix; | ||||
|             } | ||||
| } | ||||
|  | ||||
| // Signed INT to ASCII | ||||
| void itoa (int value, char *string, unsigned int radix) | ||||
| { | ||||
|       if (radix < 2 || radix>36) return; | ||||
|        | ||||
|       // Calculate how much space needed for number | ||||
|       int len, temp = abs(value); | ||||
|       for (len = 0; temp > 0; len++) temp/=radix; | ||||
|       if (len == 0) len = 1; | ||||
|        | ||||
|       //Add a space for '-' | ||||
|       if (value<0) { | ||||
|             len++; string[0] = '-'; | ||||
|             value = abs(value); | ||||
|             } | ||||
|        | ||||
|       string[len] = 0; | ||||
|       for (len--; len >0; len-- ) { | ||||
|             string[len] = base_chars[value%radix]; | ||||
|             value/=radix; | ||||
|             } | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| // Put string on screen in specified position; can use different font colors | ||||
| void puts_pos_font(int x, int y, const char *str, byte back, byte fore) | ||||
| void puts_pos_font(int x, int y, const char *str, unsigned char back, unsigned char fore) | ||||
| { | ||||
|       int i; | ||||
|       for (i = 0; str[i] != 0; i++)  | ||||
| @@ -191,7 +648,7 @@ void puts(const char *str) | ||||
|             putc(str[i]); | ||||
| } | ||||
|  | ||||
| void puts_font(const char *str, byte back, byte fore) | ||||
| void puts_font(const char *str, unsigned char back, unsigned char fore) | ||||
| { | ||||
|       int i; | ||||
|       for (i = 0; str[i] != 0; i++) | ||||
| @@ -221,7 +678,7 @@ void put_hex_pos(int x, int y, unsigned int alpha) | ||||
|       puts_pos(x,y,nr); | ||||
| } | ||||
|  | ||||
| void put_bin (int x, int y, byte xz) | ||||
| void put_bin (int x, int y, unsigned char xz) | ||||
| { | ||||
|       int i; | ||||
|       char arr[9] = {0,0,0,0,0,0,0,0,0}; | ||||
| @@ -232,53 +689,6 @@ void put_bin (int x, int y, byte xz) | ||||
| } | ||||
|  | ||||
|  | ||||
| int printf(const char* str, ...) | ||||
| { | ||||
|       if (!str) return 0; | ||||
|        | ||||
|       va_list args; | ||||
|       va_start (args, str); | ||||
|       size_t i, len = strlen(str); | ||||
|       for (i = 0; i < len; i++) | ||||
|             switch (str[i]) { | ||||
|               case '%': | ||||
|                   switch (str[i+1]) { | ||||
|                      // Character | ||||
|                      case 'c':   {char c = va_arg (args, char); | ||||
|                                   putc(c); i++; break;} | ||||
|                      // String | ||||
|                      case 's':   {int* c = (int*) va_arg (args, char*); | ||||
|                                   puts((const char*)c); i++; break;} | ||||
|                      // Integers | ||||
|                      case 'd': | ||||
|                      case 'i':   {int c = va_arg(args, int); | ||||
|                                   char temp[32]; | ||||
|                                   itoa(c, temp, 10); | ||||
|                                   puts(temp); | ||||
|                                   i++; break;} | ||||
|                      // Integers - hex | ||||
|                      case 'X': | ||||
|                      case 'x':   {int c = va_arg(args, int); | ||||
|                                   char temp[32]; | ||||
|                                   uitoa(c, temp, 16); | ||||
|                                   puts(temp); | ||||
|                                   i++; break;} | ||||
|                                    | ||||
|                      // Integers - unsigned | ||||
|                      case 'u': { int c = va_arg(args, unsigned int); | ||||
|                                   char temp[32]; | ||||
|                                   uitoa(c, temp, 10); | ||||
|                                   puts(temp); | ||||
|                                   i++; break; | ||||
|                                   } | ||||
|                                    | ||||
|                      default: va_end(args); return 1; | ||||
|                   }; | ||||
|                break; | ||||
|                default: putc(str[i]); break; | ||||
|             } | ||||
|              | ||||
|       va_end(args); | ||||
|       return i; | ||||
| } | ||||
|  | ||||
|  | ||||
| */ | ||||
							
								
								
									
										146
									
								
								SysCore/lib/ctype.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								SysCore/lib/ctype.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | ||||
| #include<ctype.h> | ||||
|  | ||||
| unsigned char _ctype[256] = | ||||
| { | ||||
|     0,                              // -1 EOF | ||||
|     _CTYPE_ISCONTROL,               // 00 (NUL) | ||||
|     _CTYPE_ISCONTROL,               // 01 (SOH) | ||||
|     _CTYPE_ISCONTROL,               // 02 (STX) | ||||
|     _CTYPE_ISCONTROL,               // 03 (ETX) | ||||
|     _CTYPE_ISCONTROL,               // 04 (EOT) | ||||
|     _CTYPE_ISCONTROL,               // 05 (ENQ) | ||||
|     _CTYPE_ISCONTROL,               // 06 (ACK) | ||||
|     _CTYPE_ISCONTROL,               // 07 (BEL) | ||||
|     _CTYPE_ISCONTROL,               // 08 (BS) | ||||
|     _CTYPE_ISSPACE+_CTYPE_ISCONTROL,        // 09 (HT) | ||||
|     _CTYPE_ISSPACE+_CTYPE_ISCONTROL,        // 0A (LF) | ||||
|     _CTYPE_ISSPACE+_CTYPE_ISCONTROL,        // 0B (VT) | ||||
|     _CTYPE_ISSPACE+_CTYPE_ISCONTROL,        // 0C (FF) | ||||
|     _CTYPE_ISSPACE+_CTYPE_ISCONTROL,        // 0D (CR) | ||||
|     _CTYPE_ISCONTROL,               // 0E (SI) | ||||
|     _CTYPE_ISCONTROL,               // 0F (SO) | ||||
|     _CTYPE_ISCONTROL,               // 10 (DLE) | ||||
|     _CTYPE_ISCONTROL,               // 11 (DC1) | ||||
|     _CTYPE_ISCONTROL,               // 12 (DC2) | ||||
|     _CTYPE_ISCONTROL,               // 13 (DC3) | ||||
|     _CTYPE_ISCONTROL,               // 14 (DC4) | ||||
|     _CTYPE_ISCONTROL,               // 15 (NAK) | ||||
|     _CTYPE_ISCONTROL,               // 16 (SYN) | ||||
|     _CTYPE_ISCONTROL,               // 17 (ETB) | ||||
|     _CTYPE_ISCONTROL,               // 18 (CAN) | ||||
|     _CTYPE_ISCONTROL,               // 19 (EM) | ||||
|     _CTYPE_ISCONTROL,               // 1A (SUB) | ||||
|     _CTYPE_ISCONTROL,               // 1B (ESC) | ||||
|     _CTYPE_ISCONTROL,               // 1C (FS) | ||||
|     _CTYPE_ISCONTROL,               // 1D (GS) | ||||
|     _CTYPE_ISCONTROL,               // 1E (RS) | ||||
|     _CTYPE_ISCONTROL,               // 1F (US) | ||||
|     _CTYPE_ISSPACE+_CTYPE_ISBLANK,          // 20 SPACE | ||||
|     _CTYPE_ISPUNCT,                 // 21 ! | ||||
|     _CTYPE_ISPUNCT,                 // 22 " | ||||
|     _CTYPE_ISPUNCT,                 // 23 # | ||||
|     _CTYPE_ISPUNCT,                 // 24 $ | ||||
|     _CTYPE_ISPUNCT,                 // 25 % | ||||
|     _CTYPE_ISPUNCT,                 // 26 & | ||||
|     _CTYPE_ISPUNCT,                 // 27 ' | ||||
|     _CTYPE_ISPUNCT,                 // 28 ( | ||||
|     _CTYPE_ISPUNCT,                 // 29 ) | ||||
|     _CTYPE_ISPUNCT,                 // 2A * | ||||
|     _CTYPE_ISPUNCT,                 // 2B + | ||||
|     _CTYPE_ISPUNCT,                 // 2C , | ||||
|     _CTYPE_ISPUNCT,                 // 2D - | ||||
|     _CTYPE_ISPUNCT,                 // 2E . | ||||
|     _CTYPE_ISPUNCT,                 // 2F / | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 30 0 | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 31 1 | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 32 2 | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 33 3 | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 34 4 | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 35 5 | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 36 6 | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 37 7 | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 38 8 | ||||
|     _CTYPE_ISDIGIT+_CTYPE_ISHEX,            // 39 9 | ||||
|     _CTYPE_ISPUNCT,                 // 3A : | ||||
|     _CTYPE_ISPUNCT,                 // 3B ; | ||||
|     _CTYPE_ISPUNCT,                 // 3C < | ||||
|     _CTYPE_ISPUNCT,                 // 3D = | ||||
|     _CTYPE_ISPUNCT,                 // 3E > | ||||
|     _CTYPE_ISPUNCT,                 // 3F ? | ||||
|     _CTYPE_ISPUNCT,                 // 40 @ | ||||
|     _CTYPE_ISUPPER+_CTYPE_ISHEX,            // 41 A | ||||
|     _CTYPE_ISUPPER+_CTYPE_ISHEX,            // 42 B | ||||
|     _CTYPE_ISUPPER+_CTYPE_ISHEX,            // 43 C | ||||
|     _CTYPE_ISUPPER+_CTYPE_ISHEX,            // 44 D | ||||
|     _CTYPE_ISUPPER+_CTYPE_ISHEX,            // 45 E | ||||
|     _CTYPE_ISUPPER+_CTYPE_ISHEX,            // 46 F | ||||
|     _CTYPE_ISUPPER,                 // 47 G | ||||
|     _CTYPE_ISUPPER,                 // 48 H | ||||
|     _CTYPE_ISUPPER,                 // 49 I | ||||
|     _CTYPE_ISUPPER,                 // 4A J | ||||
|     _CTYPE_ISUPPER,                 // 4B K | ||||
|     _CTYPE_ISUPPER,                 // 4C L | ||||
|     _CTYPE_ISUPPER,                 // 4D M | ||||
|     _CTYPE_ISUPPER,                 // 4E N | ||||
|     _CTYPE_ISUPPER,                 // 4F O | ||||
|     _CTYPE_ISUPPER,                 // 50 P | ||||
|     _CTYPE_ISUPPER,                 // 51 Q | ||||
|     _CTYPE_ISUPPER,                 // 52 R | ||||
|     _CTYPE_ISUPPER,                 // 53 S | ||||
|     _CTYPE_ISUPPER,                 // 54 T | ||||
|     _CTYPE_ISUPPER,                 // 55 U | ||||
|     _CTYPE_ISUPPER,                 // 56 V | ||||
|     _CTYPE_ISUPPER,                 // 57 W | ||||
|     _CTYPE_ISUPPER,                 // 58 X | ||||
|     _CTYPE_ISUPPER,                 // 59 Y | ||||
|     _CTYPE_ISUPPER,                 // 5A Z | ||||
|     _CTYPE_ISPUNCT,                 // 5B [ | ||||
|     _CTYPE_ISPUNCT,                 // 5C backslash | ||||
|     _CTYPE_ISPUNCT,                 // 5D ] | ||||
|     _CTYPE_ISPUNCT,                 // 5E ^ | ||||
|     _CTYPE_ISPUNCT,                 // 5F _ | ||||
|     _CTYPE_ISPUNCT,                 // 60 ` | ||||
|     _CTYPE_ISLOWER+_CTYPE_ISHEX,            // 61 a | ||||
|     _CTYPE_ISLOWER+_CTYPE_ISHEX,            // 62 b | ||||
|     _CTYPE_ISLOWER+_CTYPE_ISHEX,            // 63 c | ||||
|     _CTYPE_ISLOWER+_CTYPE_ISHEX,            // 64 d | ||||
|     _CTYPE_ISLOWER+_CTYPE_ISHEX,            // 65 e | ||||
|     _CTYPE_ISLOWER+_CTYPE_ISHEX,            // 66 f | ||||
|     _CTYPE_ISLOWER,                 // 67 g | ||||
|     _CTYPE_ISLOWER,                 // 68 h | ||||
|     _CTYPE_ISLOWER,                 // 69 i | ||||
|     _CTYPE_ISLOWER,                 // 6A j | ||||
|     _CTYPE_ISLOWER,                 // 6B k | ||||
|     _CTYPE_ISLOWER,                 // 6C l | ||||
|     _CTYPE_ISLOWER,                 // 6D m | ||||
|     _CTYPE_ISLOWER,                 // 6E n | ||||
|     _CTYPE_ISLOWER,                 // 6F o | ||||
|     _CTYPE_ISLOWER,                 // 70 p | ||||
|     _CTYPE_ISLOWER,                 // 71 q | ||||
|     _CTYPE_ISLOWER,                 // 72 r | ||||
|     _CTYPE_ISLOWER,                 // 73 s | ||||
|     _CTYPE_ISLOWER,                 // 74 t | ||||
|     _CTYPE_ISLOWER,                 // 75 u | ||||
|     _CTYPE_ISLOWER,                 // 76 v | ||||
|     _CTYPE_ISLOWER,                 // 77 w | ||||
|     _CTYPE_ISLOWER,                 // 78 x | ||||
|     _CTYPE_ISLOWER,                 // 79 y | ||||
|     _CTYPE_ISLOWER,                 // 7A z | ||||
|     _CTYPE_ISPUNCT,                 // 7B { | ||||
|     _CTYPE_ISPUNCT,                 // 7C + | ||||
|     _CTYPE_ISPUNCT,                 // 7D } | ||||
|     _CTYPE_ISPUNCT,                 // 7E ~ | ||||
|     _CTYPE_ISCONTROL,               // 7F (DEL) | ||||
|     // and the rest are 0... | ||||
| }; | ||||
|  | ||||
|  | ||||
| int toupper(int c) | ||||
| { | ||||
|     return ((islower(c)) ? (c-'a'+'A') : c); | ||||
| } | ||||
|  | ||||
| int tolower(int c) | ||||
| { | ||||
|     return((isupper(c)) ? (c-'A'+'a') : c); | ||||
| } | ||||
							
								
								
									
										286
									
								
								SysCore/lib/stdlib.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										286
									
								
								SysCore/lib/stdlib.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,286 @@ | ||||
| #include <stdlib.h> | ||||
| #include <ctype.h> | ||||
|  | ||||
| const char base_chars[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"; | ||||
|  | ||||
| void uitoa (unsigned int value, char *string, int radix) | ||||
| { | ||||
|       if (radix == 1 || radix>36) return; | ||||
|  | ||||
|       // Variables | ||||
|       int len; *string = '0'; | ||||
|       unsigned int temp = value; | ||||
|  | ||||
|       // Calculate string length needed | ||||
|       for (len = 0; temp > 0; len++) temp /= radix; | ||||
|       if (len == 0) len = 2; | ||||
|  | ||||
|       // Last character is NULL | ||||
|       string[len] = 0; | ||||
|  | ||||
|       // Write characters | ||||
|       for (len--; len >=0; len-- ) { | ||||
|             string[len] = base_chars[value%radix]; | ||||
|             value/=radix; | ||||
|             } | ||||
| } | ||||
|  | ||||
| void ultoa (unsigned long value, char *string, int radix) | ||||
| { | ||||
|       if (radix == 1 || radix>36) return; | ||||
|  | ||||
|       // Variables | ||||
|       int len; *string = '0'; | ||||
|       unsigned long temp = value; | ||||
|  | ||||
|       // Calculate string length needed | ||||
|       for (len = 0; temp > 0; len++) temp /= radix; | ||||
|       if (len == 0) len = 2; | ||||
|  | ||||
|       // Last character is NULL | ||||
|       string[len] = 0; | ||||
|  | ||||
|       // Write characters | ||||
|       for (len--; len >=0; len-- ) { | ||||
|             string[len] = base_chars[value%radix]; | ||||
|             value/=radix; | ||||
|             } | ||||
| } | ||||
|  | ||||
| void itoa (signed int value, char *string, int radix) | ||||
| { | ||||
|       if (radix == 1 || radix>36) return; | ||||
|  | ||||
|       // Variables | ||||
|       int len = 0; *string = '0'; | ||||
|       unsigned int copy = value; | ||||
|  | ||||
|       // If number is < 0 | ||||
|       if (value < 0) { | ||||
|           if (radix == 10) { | ||||
|               len++; copy = abs(value); | ||||
|           } | ||||
|           else copy = (unsigned) value;      // If base is not 10, set high bit | ||||
|       } | ||||
|  | ||||
|       // Calculate string length needed | ||||
|       unsigned int temp = copy; | ||||
|       for (; temp > 0; len++) temp /= radix; | ||||
|       if (len == 0) len = 2; | ||||
|  | ||||
|       // Last character is NULL | ||||
|       string[len] = 0; | ||||
|  | ||||
|       // Write characters | ||||
|       for (len--; len >= 0; len-- ) { | ||||
|             string[len] = base_chars[copy%radix]; | ||||
|             copy/=radix; | ||||
|             } | ||||
|  | ||||
|       // Add minus sign | ||||
|       if (value < 0 && radix == 10) string[0] = '-'; | ||||
| } | ||||
|  | ||||
| void ltoa (signed long value, char *string, int radix) | ||||
| { | ||||
|       if (radix == 1 || radix>36) return; | ||||
|  | ||||
|       // Variables | ||||
|       int len = 0; *string = '0'; | ||||
|       unsigned long copy = value; | ||||
|  | ||||
|       // If number is < 0 | ||||
|       if (value < 0) { | ||||
|           if (radix == 10) { | ||||
|               len++; copy = abs(value); | ||||
|           } | ||||
|           else copy = (unsigned) value;      // If base is not 10, set high bit | ||||
|       } | ||||
|  | ||||
|       // Calculate string length needed | ||||
|       unsigned long temp = copy; | ||||
|       for (; temp > 0; len++) temp /= radix; | ||||
|       if (len == 0) len = 2; | ||||
|  | ||||
|       // Last character is NULL | ||||
|       string[len] = 0; | ||||
|  | ||||
|       // Write characters | ||||
|       for (len--; len >= 0; len-- ) { | ||||
|             string[len] = base_chars[copy%radix]; | ||||
|             copy/=radix; | ||||
|             } | ||||
|  | ||||
|       // Add minus sign | ||||
|       if (value < 0 && radix == 10) string[0] = '-'; | ||||
| } | ||||
|  | ||||
| int atoi (const char* string) | ||||
| { | ||||
|     int ret = 0; | ||||
|     unsigned char sign = 0; | ||||
|  | ||||
|     for (;!isdigit((unsigned char)*string); string++) { | ||||
|         if (*string == NULL) return 0; | ||||
|         else if (*string == '-' && isdigit(*(string+1))) | ||||
|             sign = 1; | ||||
|     } | ||||
|  | ||||
|     for (;isdigit(*string); string++) | ||||
|         ret = ret*10 + (*string - '0'); | ||||
|  | ||||
|     if (sign) ret*=-1; | ||||
|  | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| long atol (const char* string) | ||||
| { | ||||
|     long int ret = 0; | ||||
|     unsigned char sign = 0; | ||||
|  | ||||
|     for (;!isdigit(*string); string++) { | ||||
|         if (*string == NULL) return 0; | ||||
|         else if (*string == '-' && *(string+1) > '0' && *(string+1) < '9') | ||||
|             sign = 1; | ||||
|     } | ||||
|  | ||||
|     for (;isdigit(*string); string++) | ||||
|         ret = ret*10 + (*string - '0'); | ||||
|  | ||||
|     if (sign) ret*=-1; | ||||
|  | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| unsigned int atox (const char* string) | ||||
| { | ||||
|     unsigned ret = 0; | ||||
|     unsigned temp; | ||||
|  | ||||
|     for (;!isxdigit(*string); string++) | ||||
|         if (*string == 0) return 0; | ||||
|  | ||||
|     for (;isxdigit(*string); string++) { | ||||
|         if (isdigit(*string)) temp = (unsigned)*string - '0'; | ||||
|         else if (isupper(*string)) temp = 10 + (unsigned)(*string) - 'A'; | ||||
|         else temp = 10 + (unsigned)(*string) - 'a'; | ||||
|         ret = ret*0x10 + temp; | ||||
|     } | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| void* bsearch (const void* key, const void* base, unsigned nelem, unsigned width, int (*fcmp)(const void*, const void*)) | ||||
| { | ||||
|     int beg = 0, end = nelem, mid, result; | ||||
|     unsigned addr; | ||||
|  | ||||
|     while (beg != end && beg != end-1) { | ||||
|         mid = (beg + end) / 2; | ||||
|         addr = (unsigned)base + (mid * width); | ||||
|         result = (*fcmp)(key, (void*) addr); | ||||
|  | ||||
|         if (result == 0) return (void*) addr; | ||||
|         else if (result > 0) beg = mid; | ||||
|         else end = mid; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| void* lfind (const void* key, const void* base, unsigned nelem, unsigned width, int (*fcmp)(const void*, const void*)) | ||||
| { | ||||
|     int result = 1, i = 0; | ||||
|  | ||||
|     while (result != 0 && i != nelem) { | ||||
|         base = (void*)((unsigned)base + width); | ||||
|         result = (*fcmp)(key, base); | ||||
|         i++; | ||||
|     } | ||||
|  | ||||
|     if (result == 0) return (void*) base; | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| div_t div (int numerator, int denominator) | ||||
| { | ||||
|     div_t ret; | ||||
|     ret.quot = numerator / denominator; | ||||
|     ret.rem = numerator % denominator; | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| ldiv_t ldiv (long numerator, long denominator) | ||||
| { | ||||
|     ldiv_t ret; | ||||
|     ret.quot = numerator / denominator; | ||||
|     ret.rem = numerator % denominator; | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| inline void __qassign (void *dest, void *source, unsigned width) | ||||
| { | ||||
|     unsigned char* dst = (unsigned char*)dest; | ||||
|     unsigned char* src = (unsigned char*)source; | ||||
|     int i; | ||||
|  | ||||
|     for (i = 0; i < width; i++, dst++, src++) | ||||
|         *dst = *src; | ||||
|  | ||||
| } | ||||
|  | ||||
| void __qsort(void* base, unsigned width, int (*fcmp)(const void*, const void*), int beg, int end) | ||||
| { | ||||
|     unsigned char piv_str[width]; | ||||
|     unsigned char tmp_str[width]; | ||||
|     void* piv = (void*) piv_str; void* tmp = (void*) tmp_str; | ||||
|  | ||||
|     int  l,r,p; | ||||
|  | ||||
|     while (beg<end)    // This while loop will avoid the second recursive call | ||||
|     { | ||||
|         l = beg; p = (beg+end)/2; r = end; | ||||
|  | ||||
|         __qassign(piv, (void*) ((unsigned)base + (width * p)), width); | ||||
|         //piv = (void*) ((unsigned)base + (width * p)); | ||||
|  | ||||
|         while (1) | ||||
|         { | ||||
|             while ( (l<=r) && ( (*fcmp)( (void*) ((unsigned)base + (width * l)) ,piv) <= 0 ) ) l++; | ||||
|             while ( (l<=r) && ( (*fcmp)( (void*) ((unsigned)base + (width * r)) ,piv)  > 0 ) ) r--; | ||||
|  | ||||
|             if (l>r) break; | ||||
|  | ||||
|             __qassign (tmp, (void*) ((unsigned)base + (width * l)), width); | ||||
|             __qassign ((void*) ((unsigned)base + (width * l)), (void*) ((unsigned)base + (width * r)), width); | ||||
|             __qassign ((void*) ((unsigned)base + (width * r)), tmp, width); | ||||
|             //tmp=base[l]; base[l]=base[r]; base[r]=tmp; | ||||
|  | ||||
|             if (p==r) p=l; | ||||
|  | ||||
|             l++; r--; | ||||
|         } | ||||
|  | ||||
|         __qassign((void*) ((unsigned)base + (width * p)), (void*) ((unsigned)base + (width * r)), width); | ||||
|         __qassign((void*) ((unsigned)base + (width * r)), piv, width); | ||||
|         //base[p]=base[r]; base[r]=piv; | ||||
|         r--; | ||||
|  | ||||
|         // Recursion on the shorter side & loop (with new indexes) on the longer | ||||
|         if ((r-beg)<(end-l)) | ||||
|         { | ||||
|             __qsort(base, width, *fcmp, beg, r); | ||||
|             beg=l; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             __qsort(base, width, *fcmp, l, end); | ||||
|             end=r; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| void qsort (void* base, unsigned nelem, unsigned width, int (*fcmp)(const void*, const void*)) | ||||
| { | ||||
|     __qsort(base, width, *fcmp, 0, nelem-1); | ||||
| } | ||||
|  | ||||
| @@ -1,8 +1,8 @@ | ||||
| #include <string.h> | ||||
|  | ||||
| size_t strlen (const char *str) | ||||
| unsigned strlen (const char *str) | ||||
| { | ||||
|       size_t i; | ||||
|       unsigned i; | ||||
|       for (i = 0; *str!=0; str++) i++; | ||||
|       return i; | ||||
| } | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|  | ||||
| #include <system.h> | ||||
|  | ||||
| byte *TextVideoRam; | ||||
| extern unsigned char *TextVideoRam; | ||||
| volatile int cursor_x, cursor_y; | ||||
| int current_mode_width; | ||||
| int current_mode_height; | ||||
| @@ -32,13 +32,13 @@ unsigned short *memsetw(unsigned short *dest, unsigned short val, int count) | ||||
| } | ||||
|  | ||||
|  | ||||
| byte inportb (word _port) { | ||||
|       byte rv; | ||||
| unsigned char inportb (word _port) { | ||||
|       unsigned char rv; | ||||
|       __asm__ __volatile__ ("inb %1, %0" : "=a" (rv) : "dN" (_port)); | ||||
|       return rv; | ||||
| } | ||||
| byte inb (word _port) { | ||||
|       byte rv; | ||||
| unsigned char inb (word _port) { | ||||
|       unsigned char rv; | ||||
|       __asm__ __volatile__ ("inb %1, %0" : "=a" (rv) : "dN" (_port)); | ||||
|       return rv; | ||||
| } | ||||
| @@ -1,13 +1,13 @@ | ||||
| #include <system.h> | ||||
| #include <time.h> | ||||
|  | ||||
| const char* clock_months[] = {0,  | ||||
| const char* clock_month[] = {0,  | ||||
|       "January", "February", "March", "April", "May", "June", | ||||
|       "July", "August", "September", "October", "November", "December"}; | ||||
| const char* clock_weekdays[] = {0, | ||||
| const char* clock_weekday[] = {0, | ||||
|       "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"}; | ||||
|  | ||||
| byte clock_months_len[] = { | ||||
| unsigned char clock_months_len[] = { | ||||
|       0, | ||||
|       31,   // January | ||||
|       28,   // February | ||||
| @@ -26,14 +26,14 @@ byte clock_months_len[] = { | ||||
| void _CLOCK_INC(TIME *tim) | ||||
| { | ||||
|       // New minute | ||||
|       if (++tim->seconds > 59) { | ||||
|         tim->seconds = 0; | ||||
|       if (++tim->second > 59) { | ||||
|         tim->second = 0; | ||||
|         // New hour | ||||
|         if (++tim->minutes > 59) { | ||||
|            tim->minutes = 0; | ||||
|            tim->hours++; | ||||
|            if (tim->hours == 12 && tim->am_pm == 1) {     // 11:59pm -> 0:00am | ||||
|               tim->hours = 0; tim->am_pm = 0; | ||||
|         if (++tim->minute > 59) { | ||||
|            tim->minute = 0; | ||||
|            tim->hour++; | ||||
|            if (tim->hour == 24) {     // Midnight | ||||
|               tim->hour = 0; | ||||
|               // New day | ||||
|               tim->weekday = 1+(tim->weekday%7); | ||||
|               // Leap years | ||||
| @@ -49,8 +49,6 @@ void _CLOCK_INC(TIME *tim) | ||||
| 			      } | ||||
| 			} | ||||
| 		  } | ||||
|             else if (tim->hours == 12 && tim->am_pm == 0) tim->am_pm = 1; // 11:59am -> 12:00pm | ||||
|             else if (tim->hours == 13 && tim->am_pm == 1) tim->hours = 1; // 12:59pm -> 1:59pm | ||||
| 	      } | ||||
|        } | ||||
| } | ||||
| @@ -69,7 +67,7 @@ void _CLOCK_INC(TIME *tim) | ||||
| { | ||||
|       char str[100]; | ||||
|       int l = strlen(format), i; | ||||
|       byte special = 0; | ||||
|       unsigned char special = 0; | ||||
|        | ||||
|       for (i=0; i<l-1 && i<100; i++) { | ||||
|             if (format[i] == '%') switch (format[i+1]) { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ global start | ||||
| start:  jmp stub | ||||
|      | ||||
|  | ||||
| stub:       cmp eax, 0x2badb002 | ||||
| stub:       cmp eax, 0xC0DEcC7A | ||||
|             jne .bad | ||||
|              | ||||
|             mov ax, 10h | ||||
| @@ -19,8 +19,6 @@ stub:       cmp eax, 0x2badb002 | ||||
| .bad:             | ||||
|             cli | ||||
|             hlt | ||||
|  | ||||
|        | ||||
|       | ||||
| SECTION .bss | ||||
|     resb 8192               ; This reserves 8KBytes of memory here | ||||
| @@ -2,79 +2,71 @@ | ||||
| #include <system.h> | ||||
| #include <conio.h> | ||||
| #include <hal.h> | ||||
| #include "hal/floppy/floppy.h" | ||||
| #include <time.h> | ||||
| #include <bootinfo.h> | ||||
| #include "memory/mmngr_ph.h" | ||||
| #include "memory/mmngr_vi.h" | ||||
| #include "shell/shell.c" | ||||
| #include "video/vga03h.h" | ||||
|  | ||||
| //! format of a memory region | ||||
| #include <stdlib.h> | ||||
|  | ||||
| // format of a memory region | ||||
| typedef struct { | ||||
|  | ||||
| 	uint32_t	startLo; | ||||
| 	uint32_t	startHi; | ||||
| 	uint32_t	sizeLo; | ||||
| 	uint32_t	sizeHi; | ||||
| 	uint32_t	type; | ||||
| 	uint32_t	acpi_3_0; | ||||
| 	unsigned	startLo; | ||||
| 	unsigned	startHi; | ||||
| 	unsigned	sizeLo; | ||||
| 	unsigned	sizeHi; | ||||
| 	unsigned	type; | ||||
| 	unsigned	acpi_3_0; | ||||
| } memory_region ; | ||||
|  | ||||
| //! different memory regions (in memory_region.type) | ||||
| char* strMemoryTypes[] = { | ||||
| // different memory regions (in memory_region.type) | ||||
| /*char* strMemoryTypes[] = { | ||||
|       "", | ||||
| 	"Available",			//memory_region.type==0 | ||||
|       "Reserved",			//memory_region.type==1 | ||||
| 	"ACPI Reclaim",		//memory_region.type==2 | ||||
| 	"ACPI NVS Memory"		//memory_region.type==3 | ||||
| }; | ||||
| };*/ | ||||
|  | ||||
| extern dword _code; | ||||
| extern dword _data; | ||||
| extern dword _bss; | ||||
| extern dword _end; | ||||
| extern void _code, _data, _bss, _end; | ||||
|  | ||||
| void k_init(multiboot_info* bootinfo) | ||||
| { | ||||
|       // Start by zero-ing the bss | ||||
|       memset(&_bss, 0, &_end - &_bss); | ||||
|        | ||||
|       // Initialize HAL | ||||
|       i86_hal_initialize(); | ||||
|  | ||||
|       // Initialize Graphics | ||||
|       graphics_init(); | ||||
|        | ||||
|       // cleanup the console screen | ||||
|       set_default_colors (0x07, 0x04); | ||||
|       clrscr(); | ||||
|  | ||||
|       // Start memory manager | ||||
|       uint32_t memSize = 1024 + bootinfo->m_memoryLo + bootinfo->m_memoryHi*64; | ||||
|    	memory_region* memMap = (memory_region*)0x1000; | ||||
|       pmmngr_init (memSize, (uint32_t)&_end); | ||||
|  | ||||
|       memset(&_bss, 0, &_end - &_bss);                // zero the bss | ||||
|       unsigned int i; | ||||
|  | ||||
|       for (i=0; (memMap[i].sizeHi != 0 || memMap[i].sizeLo != 0) && i<15; ++i)  | ||||
| 		if (memMap[i].type==1) pmmngr_init_region (memMap[i].startLo, memMap[i].sizeLo); | ||||
|  | ||||
|       // Protect kernel, bios data area etc | ||||
|       _end += (memSize / 4) * 3; | ||||
|       pmmngr_deinit_region (0x100000, _end - 0x100000); | ||||
|       pmmngr_deinit_region (0x0, 0x500); | ||||
|       pmmngr_deinit_region (0x9FC00, 0x400); | ||||
|       pmmngr_deinit_region (0xA0000, 0x60000); | ||||
|       // Start phyiscal memory manager | ||||
|       unsigned memSize = bootinfo->Memory; | ||||
|        | ||||
|       // Start Virtual Memory Manager & Enable paging | ||||
|       memory_region* memMap = bootinfo->MemoryMapAddress; | ||||
|       pmmngr_init (memSize, (unsigned)&_end); | ||||
|  | ||||
|       // Initialize graphics & HAL | ||||
|       //graphics_init(); | ||||
|       i86_hal_initialize(); | ||||
|  | ||||
|       // Initialize memory | ||||
|       for (i=0; (memMap[i].sizeHi != 0 || memMap[i].sizeLo != 0) && i<15; ++i)  | ||||
| 		if (memMap[i].type==1)  | ||||
|                   pmmngr_init_region (memMap[i].startLo, memMap[i].sizeLo); | ||||
|                    | ||||
|       // Protect kernel, bios data area etc | ||||
|       pmmngr_deinit_region (0x100000, 4096+(unsigned)((&_end) + (memSize / 4)*3) - 0xC0000000); | ||||
|       pmmngr_deinit_region (0x0, 0x500);                    // IVT, Bios Data Area | ||||
|  | ||||
|       // Initialize virtual mem manager | ||||
|       vmmngr_initialize(); | ||||
| } | ||||
|  | ||||
| void k_main(uint32_t kernel_size, multiboot_info* bootinfo) | ||||
| { | ||||
|       k_init(bootinfo); | ||||
|       apps_osver(); | ||||
|        | ||||
|       shell(); | ||||
|  | ||||
|       for(;;); | ||||
| extern void shell(); | ||||
| void k_main(unsigned kernel_size, multiboot_info* bootinfo) | ||||
| { | ||||
|     k_init(bootinfo); | ||||
|     vga03h_install(); | ||||
|  | ||||
|     shell(); | ||||
|     for(;;); | ||||
| } | ||||
| @@ -33,14 +33,24 @@ goto KernelEntry | ||||
|  | ||||
| :KernelSTDLIB | ||||
|       cd lib | ||||
|       rem call compile.bat | ||||
|       call compile.bat | ||||
|       cd.. | ||||
|  | ||||
| :KernelMemoryManager | ||||
|       cd memory | ||||
|       rem call compile.bat | ||||
|       cd.. | ||||
|        | ||||
|  | ||||
| :KernelVIDEO | ||||
|       cd video | ||||
|       call compile.bat | ||||
|       cd.. | ||||
|        | ||||
| :KernelSHELL | ||||
|       cd shell | ||||
|       call compile.bat | ||||
|       cd.. | ||||
| rem here go other sources: | ||||
|  | ||||
| rem here go other sources ^ | ||||
|   | ||||
| @@ -48,6 +48,16 @@ goto KernelEntry | ||||
|       call makeall.bat | ||||
|       cd.. | ||||
|        | ||||
| :KernelVIDEO | ||||
|       cd video | ||||
|       call compile.bat | ||||
|       cd.. | ||||
|        | ||||
| :KernelSHELL | ||||
|       cd shell | ||||
|       call compile.bat | ||||
|       cd.. | ||||
|  | ||||
| rem here go other sources: | ||||
|  | ||||
| rem here go other sources ^ | ||||
|   | ||||
| @@ -22,4 +22,24 @@ void pt_entry_add_attrib (pt_entry* entry, unsigned mask) { | ||||
|   | ||||
|  unsigned char pt_entry_is_writable (pt_entry entry) { | ||||
|       return (entry & _I86_PTE_WRITABLE); | ||||
| } | ||||
| } | ||||
|  | ||||
|  | ||||
| /*#include <conio.h> | ||||
|  | ||||
| void pt_entry_print(pt_entry entry) | ||||
| { | ||||
|       cprintf ("page <FRAME=%u", entry & _I86_PTE_FRAME); | ||||
|        | ||||
|       if (entry & _I86_PTE_PRESENT) cprintf (" PRESENT"); | ||||
|       if (entry & _I86_PTE_WRITABLE) cprintf (" WRITABLE"); | ||||
|       if (entry & _I86_PTE_USER) cprintf (" USER"); | ||||
|       if (entry & _I86_PTE_WRITETHROUGH) cprintf (" WRITETHROUGH"); | ||||
|       if (entry & _I86_PTE_NOT_CACHEABLE) cprintf (" NOT-CACHEABLE"); | ||||
|       if (entry & _I86_PTE_ACCESSED) cprintf (" ACCESSED"); | ||||
|       if (entry & _I86_PTE_DIRTY) cprintf (" DIRTY"); | ||||
|       if (entry & _I86_PTE_PAT) cprintf (" PAT"); | ||||
|       if (entry & _I86_PTE_CPU_GLOBAL) cprintf (" CPU-GLOBAL"); | ||||
|       if (entry & _I86_PTE_LV4_GLOBAL) cprintf (" LV4-GLOBAL"); | ||||
|       cprintf(">"); | ||||
| }*/ | ||||
| @@ -24,4 +24,6 @@ extern unsigned pt_entry_get_frame (pt_entry entry); | ||||
|  | ||||
| extern unsigned char pt_entry_is_present (pt_entry entry); | ||||
| extern unsigned char pt_entry_is_writable (pt_entry entry); | ||||
|  | ||||
| extern void pt_entry_print(pt_entry entry); | ||||
| #endif | ||||
| @@ -21,6 +21,7 @@ _read_cr3: | ||||
|        | ||||
| global _write_cr3 | ||||
| _write_cr3: | ||||
|       ;xchg bx, bx      ; bochs magic breakpoint | ||||
|       push ebp | ||||
|       mov ebp, esp | ||||
|       mov eax, [ebp+8] | ||||
| @@ -34,4 +35,4 @@ _vmmngr_flush_tbl_entry: | ||||
|       cli | ||||
|       invlpg [eax] | ||||
|       sti | ||||
|       retn | ||||
|       retn | ||||
| @@ -1,6 +1,9 @@ | ||||
| /****************************************************** | ||||
|  *          Physical Memory Manager                   * | ||||
|  ******************************************************/ | ||||
| /********************************************************************* | ||||
|  * (c) 2010 CTA Systems Inc. All rights reserved. Glory To God       * | ||||
|  *                                                                   * | ||||
|  *          Physical Memory Manager                                  * | ||||
|  *          =======================                                  * | ||||
|  ************************************************************ cta os */ | ||||
|  | ||||
| // +==============================================+ | ||||
| // |    HEADERS                                   | | ||||
| @@ -129,7 +132,7 @@ void mstack_qsort(int beg, int end) | ||||
| /*void print_stack() | ||||
| { | ||||
|       int i; | ||||
|       for (i = 0; i < _mmngr_index; i++) printf (" %u", _mmngr_memory_stack[i].low); | ||||
|       for (i = 0; i < _mmngr_index; i++) \n\r (" %u", _mmngr_memory_stack[i].low); | ||||
| } | ||||
| extern char getch();*/ | ||||
|  | ||||
| @@ -285,15 +288,15 @@ void* pmmngr_alloc_blocks (unsigned blocks) | ||||
|       unsigned prev = _mmngr_memory_stack[i].low | (_mmngr_memory_stack[i].high<<16); --i; | ||||
|        | ||||
|       // Search consecutive blocks  | ||||
|       for (; i >=0; i--) { | ||||
|       for (i = 0; i < _mmngr_index; i++) { | ||||
|             temp = _mmngr_memory_stack[i].low | (_mmngr_memory_stack[i].high<<16); | ||||
|  | ||||
|             if (temp == prev-1) l++; | ||||
|             if (temp == prev+1) l++; | ||||
|             else l = 1; | ||||
|              | ||||
|             if (l == blocks) { | ||||
|                   pmmngr_deinit_region (temp * PMMNGR_BLOCK_SIZE, blocks * PMMNGR_BLOCK_SIZE); | ||||
|                   return (void*) (temp * PMMNGR_BLOCK_SIZE); | ||||
|                   return (void*) ((temp-l+1) * PMMNGR_BLOCK_SIZE); | ||||
|                   } | ||||
|                    | ||||
|             prev = temp; | ||||
|   | ||||
| @@ -5,16 +5,18 @@ | ||||
| #include "mmngr_ph.h" | ||||
|  | ||||
| // +==============================================+ | ||||
| // |    DEFINITIONS                               | | ||||
| // |    DEFINITIONS & MACROS                      | | ||||
| // +===================================== cta os =+ | ||||
| #define PAGE_SIZE 4096 | ||||
| #define PTABLE_ADDR_SPACE_SIZE 0x400000 | ||||
| #define DTABLE_ADDR_SPACE_SIZE 0xffffffff | ||||
| #define PAGE_DIRECTORY_INDEX(x) (((x) >> 22) & 0x3ff) | ||||
| #define PAGE_TABLE_INDEX(x) (((x) >> 12) & 0x3ff) | ||||
| #define PAGE_GET_PHYSICAL_ADDRESS(x) (*x & ~0xfff) | ||||
|  | ||||
| pdirectory* _current_directory; | ||||
| unsigned _current_page_directory_base_register; | ||||
| extern unsigned char *memset (unsigned char *dest, unsigned char val, int count); | ||||
| extern char getch(); | ||||
|  | ||||
| // +==============================================+ | ||||
| // |    PAGE FUNCTIONS                            | | ||||
| @@ -95,39 +97,88 @@ pdirectory* vmmngr_get_directory() { | ||||
|     return _current_directory; | ||||
| } | ||||
|  | ||||
| void vmmngr_initialize() | ||||
|  | ||||
| unsigned char vmmngr_map_page (unsigned phys, unsigned virt) | ||||
| { | ||||
|       // Allocate default page table | ||||
|       ptable* table = (ptable*) pmmngr_alloc_block(); | ||||
|       if (!table) return; | ||||
|       pdirectory* dir = _current_directory;                             // get page directory | ||||
|       pd_entry* e = &dir->m_entries [PAGE_DIRECTORY_INDEX (virt)];      // get page table | ||||
|        | ||||
|       // Clear page table | ||||
|       if ((*e & _I86_PTE_PRESENT) != _I86_PTE_PRESENT) { | ||||
|        | ||||
|             // Page table not present, allocate it | ||||
|             ptable* table = (ptable *)pmmngr_alloc_block(); | ||||
|             if (!table) return 0; | ||||
|        | ||||
|             // Clear it | ||||
|             vmmngr_ptable_clear(table); | ||||
|              | ||||
|             // Create new entry | ||||
|             pd_entry* entry = &dir->m_entries [PAGE_DIRECTORY_INDEX (virt)]; | ||||
|        | ||||
|             // Map in the table | ||||
|             pd_entry_add_attrib (entry, _I86_PDE_PRESENT); | ||||
|             pd_entry_add_attrib (entry, _I86_PDE_WRITABLE); | ||||
|             pd_entry_set_frame (entry, (unsigned) table); | ||||
|       } | ||||
|        | ||||
|       // get table | ||||
|       ptable* table = (ptable*) PAGE_GET_PHYSICAL_ADDRESS(e); | ||||
|        | ||||
|       // get page | ||||
|       pt_entry* page =  &table->m_entries [PAGE_TABLE_INDEX (virt)]; | ||||
|        | ||||
|       pt_entry_set_frame (page, phys); | ||||
|       pt_entry_add_attrib (page, _I86_PTE_PRESENT); | ||||
|        | ||||
|       return 1; | ||||
| } | ||||
|  | ||||
| unsigned char vmmngr_initialize() | ||||
| { | ||||
|       unsigned int i, virt, frame; | ||||
|        | ||||
|       // Allocate default page & directory table(s) | ||||
|       ptable* table = (ptable*) pmmngr_alloc_block(); | ||||
|       ptable* table2 = (ptable*) pmmngr_alloc_block(); | ||||
|       pdirectory* dir = (pdirectory*) pmmngr_alloc_blocks(3); | ||||
|  | ||||
|       if (!table || !table2 || !dir) return 0;    | ||||
|           | ||||
|       // Clear page & directory tables | ||||
|       vmmngr_ptable_clear(table); | ||||
|       vmmngr_ptable_clear(table2); | ||||
|       vmmngr_pdirectory_clear(dir); | ||||
|        | ||||
|       // Identity map the first page table | ||||
|       int i, frame; | ||||
|       for (i = 0, frame = 0; i < 1024; i++, frame += 4096) | ||||
|       virt = 0; frame = 0; | ||||
|       for (i = 0; i < 1024; i++, virt+=4096, frame += 4096) | ||||
|       { | ||||
|             // Create a new page | ||||
|             pt_entry page = 0; | ||||
|             pt_entry_add_attrib (&page, _I86_PTE_PRESENT); | ||||
|             pt_entry_set_frame (&page, frame); | ||||
|              | ||||
|             table->m_entries[vmmngr_ptable_virt_to_index(frame)] = page; | ||||
|             pt_entry* page = &table2->m_entries[PAGE_TABLE_INDEX(virt)]; | ||||
|             *page = 0; | ||||
|             pt_entry_add_attrib (page, _I86_PTE_PRESENT); | ||||
|             pt_entry_set_frame (page, frame); | ||||
|       } | ||||
|  | ||||
|       // Create default directory table | ||||
|       pdirectory* dir = (pdirectory*) pmmngr_alloc_blocks(3); | ||||
|       if (!dir) return; | ||||
|  | ||||
|       // Clear directory table and set it as current | ||||
|       vmmngr_pdirectory_clear(dir); | ||||
|  | ||||
|       // Get first entry in dir table and set it up to point to our table | ||||
|       pd_entry* entry = vmmngr_pdirectory_lookup_entry(dir, 0); | ||||
|        | ||||
|       // Map 0x100000 to 0xC0000000 | ||||
|       virt = 0xC0000000; frame = 0x100000; | ||||
|       for (i = 0; i < 1024; i++, virt+=4096, frame += 4096) | ||||
|       { | ||||
|             pt_entry* page = &table->m_entries[PAGE_TABLE_INDEX(virt)]; | ||||
|             *page = 0; | ||||
|             pt_entry_add_attrib (page, _I86_PTE_PRESENT); | ||||
|             pt_entry_set_frame (page, frame); | ||||
|       } | ||||
|        | ||||
|       // Get tables in dir table and point them to our tables | ||||
|       pd_entry* entry = &dir->m_entries [PAGE_DIRECTORY_INDEX (0xC0000000)]; | ||||
|       pd_entry_add_attrib (entry, _I86_PDE_PRESENT); | ||||
|       pd_entry_add_attrib (entry, _I86_PDE_WRITABLE); | ||||
|       pd_entry_set_frame (entry, (unsigned) table); | ||||
|        | ||||
|       entry = &dir->m_entries [PAGE_DIRECTORY_INDEX (0x00000000)]; | ||||
|       pd_entry_add_attrib (entry, _I86_PDE_PRESENT); | ||||
|       pd_entry_add_attrib (entry, _I86_PDE_WRITABLE); | ||||
|       pd_entry_set_frame (entry, (unsigned) table2);       | ||||
|   | ||||
|       // Store current PDBR | ||||
|       _current_page_directory_base_register = (unsigned) &dir->m_entries; | ||||
| @@ -137,4 +188,6 @@ void vmmngr_initialize() | ||||
|        | ||||
|       // Enable paging | ||||
|       pmmngr_paging_enable (1); | ||||
|  | ||||
|       return 1; | ||||
| } | ||||
| @@ -20,6 +20,7 @@ typedef struct { | ||||
| //extern pdirectory* _current_directory; | ||||
|  | ||||
| extern void vmmngr_flush_tbl_entry (unsigned addr); | ||||
| extern void vmmngr_initialize(); | ||||
| extern unsigned char vmmngr_initialize(); | ||||
| extern unsigned char vmmngr_map_page(unsigned phys, unsigned virt); | ||||
|  | ||||
| #endif | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								SysCore/objects/CTYPE.O
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								SysCore/objects/CTYPE.O
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								SysCore/objects/DMA.O
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								SysCore/objects/DMA.O
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								SysCore/objects/FLOPPY.O
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								SysCore/objects/FLOPPY.O
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								SysCore/objects/SHELL.O
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								SysCore/objects/SHELL.O
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								SysCore/objects/STDLIB.O
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								SysCore/objects/STDLIB.O
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -6,6 +6,9 @@ INPUT("loader.o", | ||||
|       "cmos.o", | ||||
|       "conio.o", | ||||
|       "cpu.o", | ||||
|       "ctype.o", | ||||
|       "dma.o", | ||||
|       "floppy.o", | ||||
|       "gdt.o", | ||||
|       "gdt_asm.o", | ||||
|       "hal.o", | ||||
| @@ -23,12 +26,15 @@ INPUT("loader.o", | ||||
|       "keyus.o", | ||||
|       "pic.o", | ||||
|       "pit.o", | ||||
|       "shell.o", | ||||
|       "stdlib.o", | ||||
|       "string.o", | ||||
|       "system.o", | ||||
|       "time.o" | ||||
|       "time.o", | ||||
|       "video/vga03h.o" | ||||
| ) | ||||
| OUTPUT(kernel.bin) | ||||
| phys = 0x00100000; | ||||
| phys = 0xC0000000; | ||||
| SECTIONS | ||||
| { | ||||
|   .text phys : AT(phys) { | ||||
|   | ||||
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								SysCore/objects/video/VGA03H.O
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								SysCore/objects/video/VGA03H.O
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -1,69 +1,40 @@ | ||||
| #define hex(x)  (x < 10) ? x+'0' : x-10+'a' | ||||
|  | ||||
| const char *apps_lst[] = { | ||||
|       "", | ||||
|       "reboot", | ||||
|       "osver", | ||||
|       "time", | ||||
|       "place", | ||||
|       "cls", | ||||
|       "memory", | ||||
|       "help", | ||||
|       "cpu_info", | ||||
|       "memstat" | ||||
| /*0*/      "", | ||||
| /*1*/      "reboot", | ||||
| /*2*/      "osver", | ||||
| /*3*/      "time", | ||||
| /*4*/      "place", | ||||
| /*5*/      "cls", | ||||
| /*6*/      "dump", | ||||
| /*7*/      "help", | ||||
| /*8*/      "cpuid", | ||||
| /*9*/      "memstat", | ||||
| /*A*/      "read" | ||||
|       }; | ||||
| int apps_count = 10; | ||||
| int apps_count = 11; | ||||
|        | ||||
|  | ||||
|  | ||||
| unsigned int atox(const char* str) | ||||
| { | ||||
|       unsigned int temp = 0; | ||||
|       int i; unsigned int digit = 0; | ||||
|        | ||||
|       for (i = 0; str[i]!=0; i++) { | ||||
|        | ||||
|             if (str[i] >= '0' && str[i] <= '9') digit = str[i] - '0'; | ||||
|             else if (str[i] >= 'A' && str[i] <= 'F') digit = str[i] - 'A' + 10; | ||||
|             else if (str[i] >= 'a' && str[i] <= 'f') digit = str[i] - 'a' + 10; | ||||
|             else break; | ||||
|              | ||||
|             temp = temp*16 + digit; | ||||
|       } | ||||
|        | ||||
|       return temp; | ||||
| } | ||||
|  | ||||
| unsigned int atoui(const char* str) | ||||
| { | ||||
|       unsigned int temp = 0; | ||||
|       int i; | ||||
|        | ||||
|       for (i = 0; str[i] >= '0' && str[i] <= '9' ; i++) | ||||
|             temp = temp*10 + (str[i] - '0'); | ||||
|        | ||||
|       return temp; | ||||
| } | ||||
|  | ||||
|  | ||||
|        | ||||
| void apps_osver() | ||||
| { | ||||
|       printf ("CTA 32bit Operating System v0.1"); | ||||
|       printf ("\n(c) CTA 2010\n"); | ||||
|       cprintf ("%#0BC%#0CT%#0AA %#0F32bit Operating System v0.1\n\r"); | ||||
|       cprintf ("(c) CTA 2010\n\r"); | ||||
| } | ||||
|  | ||||
| void apps_time() | ||||
| { | ||||
|       printf ("Today is %s, %u of %s, %u%u.\n", clock_weekdays[_internal_clock.weekday], | ||||
|             (unsigned int) _internal_clock.day, clock_months[_internal_clock.month], | ||||
|             (unsigned int) _internal_clock.century, (unsigned int) _internal_clock.year); | ||||
|                                               | ||||
|       printf ("Now is %u:%u:%u.\n", (unsigned int) _internal_clock.hours, | ||||
|             (unsigned int) _internal_clock.minutes, (unsigned int) _internal_clock.seconds); | ||||
|       TIME _internal_clock = i86_pit_get_time(); | ||||
|       cprintf ("Today is %#0F%s%#07, %#0F%u %#07of %#0F%s%#07, %#0F%u%u%#07.\n\r", clock_weekday[_internal_clock.weekday], | ||||
|             (unsigned) _internal_clock.day, clock_month[_internal_clock.month], | ||||
|             (unsigned) _internal_clock.century, (unsigned) _internal_clock.year);                             | ||||
|       cprintf ("%#07Now is %#0F%u%#87:%#0F%u%#87:%#0F%u%#07.\n\r", (unsigned) _internal_clock.hour, | ||||
|             (unsigned) _internal_clock.minute, (unsigned) _internal_clock.second); | ||||
| } | ||||
|  | ||||
| void apps_place() | ||||
| { | ||||
|       printf ("On your desk, if you didn't notice... \n"); | ||||
|       cprintf ("%#0FOn your desk, %#07if you didn't notice... \n\r"); | ||||
| } | ||||
|  | ||||
| void apps_clrscr() | ||||
| @@ -71,66 +42,112 @@ void apps_clrscr() | ||||
|       clrscr(); | ||||
| } | ||||
|  | ||||
| void apps_memory(const int pn, const char* param[]) | ||||
| void apps_dump(const int pn, const char* param[]) | ||||
| { | ||||
|       if (pn<3) { | ||||
|             printf ("Correct syntax: memory [start_address] [end_address]     (in hex)\n"); | ||||
|             cprintf ("%#0CCorrect syntax:  %#07dump %#0F[start_address] %#0F[end_address]  %#0C(in hex)\n\r"); | ||||
|             return; | ||||
|             } | ||||
|              | ||||
|       byte *start, *end; | ||||
|       start = (byte *) atox (param[1]); | ||||
|       end = (byte *) atox (param[2]); | ||||
|       byte* count; | ||||
|       unsigned char *start, *end; | ||||
|       start = (unsigned char *) atox (param[1]); | ||||
|       end = (unsigned char *) atox (param[2]); | ||||
|       unsigned char* count; | ||||
|              | ||||
|       while (start <= end) { | ||||
|             put_hex ((unsigned int) start); puts(": "); | ||||
|             cprintf("%#0D%x%#07:  ", (unsigned int) start); | ||||
|              | ||||
|             for (count = start; count < start+16; count++) { | ||||
|                   putc(hex[*count/16]); putc(hex[*count%16]); | ||||
|                   putc(' '); | ||||
|                 if (*count == 0) cprintf ("%#0800 "); | ||||
|                 else cprintf ("%#0F%c%c ", hex(*count/16), hex(*count%16)); | ||||
|             } | ||||
|             puts("  "); | ||||
|              | ||||
|             cprintf("  "); | ||||
|             for (count = start; count < start+16; count++) { | ||||
|                   if (*count < 32) putc('.'); | ||||
|                   else putc(*count); | ||||
|                   if (*count < 32) cprintf("."); | ||||
|                   else cprintf("%#0A%c", *count); | ||||
|                   } | ||||
|              | ||||
|             putc('\n'); | ||||
|             cprintf("\n\r"); | ||||
|             start+=16; | ||||
|             } | ||||
|              | ||||
|              | ||||
| } | ||||
|  | ||||
| int apps_help_sort(const void* a, const void* b) | ||||
| { | ||||
|     return strcmp(apps_lst[*(short *)a], apps_lst[*(short *)b]); | ||||
| } | ||||
|  | ||||
| void apps_help(const int pn, const char* param[]) | ||||
| { | ||||
|       short arr[apps_count]; | ||||
|       int i; | ||||
|       puts ("\n"); | ||||
|  | ||||
|       for (i = 0; i < apps_count; i++) | ||||
|           arr[i] = i; | ||||
|  | ||||
|       qsort((void*)arr, apps_count, sizeof(short), apps_help_sort); | ||||
|  | ||||
|       if (pn==1) { | ||||
|             puts("[BeTA]\n"); | ||||
|             puts("Available commands:"); | ||||
|             for (i = 1; i < apps_count; i++) { | ||||
|                   puts("\n    \t "); puts((char*)apps_lst[i]); | ||||
|                   } | ||||
|             puts("\n\nUse help [command] for help on individual commands.\n"); | ||||
|             cprintf("%#0BC%#0CT%#0AA %#0FShell %#07commands:\n\r"); | ||||
|             for (i = 1; i < apps_count; i++) | ||||
|                   cprintf("%#0F\t%c %s\n\r", 0x7 ,apps_lst[arr[i]]); | ||||
|              | ||||
|             cprintf("\n\rUse help %#0E[command]%#07 for help on individual commands.\n\r"); | ||||
|             return; | ||||
|             } | ||||
|              | ||||
|       for (i = 0; strcmp(apps_lst[i], param[1])!=0 && i<apps_count; i++); | ||||
|       puts("[BeTA]\nShowing help for command: "); puts((char*)apps_lst[i]); | ||||
|       cprintf("\n\r[%#0Bc%#0Ct%#0Aa %#0APreALphA%#07] Showing help for command: %#0E%s", apps_lst[i]); | ||||
|  | ||||
|       // DESCRIPTION: | ||||
|       cprintf ("\n\r%#0FDescription:\t"); | ||||
|       switch (i) { | ||||
|                   case 0: break; | ||||
|                   case 1: puts("\n\nReboots the system.\nUsage: reboot"); break; | ||||
|                   case 2: puts("\n\nShows information about the current operating system.\nUsage: osver"); break; | ||||
|                   case 3: puts("\n\nDisplays the current date.\nUsage: date"); break; | ||||
|                   case 5: puts("\n\nClears the screen.\nUsage: cls");break; | ||||
|                   case 6: puts("\n\nShows the content of memory in the interval specified.\nUsage: memory [start_address] [end_address]");break; | ||||
|                   case 7: puts("\n\nShows a list of commands, or help for a specified command.\nUsage: help [opt:command]"); break; | ||||
|                   default: puts("Invalid function: "); puts((char*)param[1]);  | ||||
|                               break; | ||||
|           case 1: cprintf("Restarts the system."); break; | ||||
|           case 2: cprintf("Shows information about the operating system."); break; | ||||
|           case 3: cprintf("Displays the current time and date."); break; | ||||
|           case 4: cprintf("%#08A little easter egg (shhhh... don't tell anyone."); break; | ||||
|           case 5: cprintf("Clears the screen.");break; | ||||
|           case 6: cprintf("Shows the virtual memory content between the specified\n\r\t\taddresses. ");break; | ||||
|           case 7: cprintf("Displays instructions for each command, or the list of\n\r\t\tcommands if none specified."); break; | ||||
|           case 8: cprintf("Shows the CPU's vendor."); break; | ||||
|           case 9: cprintf("Displays the current status of the memory, reported by\n\r\t\tthe memory manager."); break; | ||||
|           case 0xA: cprintf ("Reads one sector from floppy disk."); break; | ||||
|           default: cprintf("%#0CInvalid function, or help not implemented. "); break; | ||||
|       } | ||||
|       puts("\n\n"); | ||||
|  | ||||
|       // USAGE: | ||||
|       cprintf ("\n\r%#0FUsage:\t\t"); | ||||
|       switch (i) { | ||||
|           case 1: cprintf("reboot"); break; | ||||
|           case 2: cprintf("osver"); break; | ||||
|           case 3: cprintf("time"); break; | ||||
|           case 4: cprintf("%#08Nobody knows. And %#07nobody %#08should ever do."); break; | ||||
|           case 5: cprintf("cls"); break; | ||||
|           case 6: cprintf("dump %#0E[start] [end]"); break; | ||||
|           case 7: cprintf("help %#0E[command]"); break; | ||||
|           case 8: cprintf("cpuid"); break; | ||||
|           case 9: cprintf("memstat"); break; | ||||
|           case 0xA: cprintf("read %#0e[sector]"); break; | ||||
|           default: cprintf("%#0CInvalid function, or help not implemented. "); break; | ||||
|       } | ||||
|  | ||||
|       // NOTES: | ||||
|       cprintf ("\n\r%#0FNotes:\t"); | ||||
|       switch (i) { | ||||
|           case 1: cprintf("\t%c Use wisely.", 0x7); break; | ||||
|           case 2: cprintf("%#08\t%c (None)", 0x7); break; | ||||
|           case 3: cprintf("%#08\t%c (None)", 0x7); break; | ||||
|           case 4: cprintf("%#08\t%c (None)", 0x7); break; | ||||
|           case 5: cprintf("%#08\t%c (None)", 0x7); break; | ||||
|           case 6: cprintf("\t%c %#0E[start]%#07 and %#0E[end]%#07 are virtual addresses in %#0Ahexadecimal%#07.", 0x7); break; | ||||
|           case 7: cprintf("\t%c The %#0E[command]%#07 parameter is optional.", 0x7); break; | ||||
|           case 8: cprintf("\t%c Shows CPU vendor returned by CPUID function.", 0x7); break; | ||||
|           case 9: cprintf("%#08\t%c (None)", 0x7); break; | ||||
|           case 0xA: cprintf("\t%c Sector is in decimal, starts from 0.", 0x7); break; | ||||
|           default: cprintf("%#0C\t%c Invalid function, or help not implemented. ", 0x7); break; | ||||
|       } | ||||
|       cprintf("\n\r"); | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -138,8 +155,20 @@ extern void detect_cpu(); | ||||
|  | ||||
| void apps_memory_status() | ||||
| { | ||||
|       printf ("Memory available: %u KB \n", pmmngr_get_memory_size ()); | ||||
|       printf ("Total blocks: %u      Used: %u        Free: %u\n", pmmngr_get_block_count (), pmmngr_get_use_block_count (), pmmngr_get_free_block_count ()); | ||||
|       printf ("Block size: %u bytes\nPaging is ", pmmngr_get_block_size()); | ||||
|       printf ( pmmngr_is_paging() ? "enabled.\n" : "disabled.\n"); | ||||
| } | ||||
|       cprintf ("Memory available: %#0F%u KB \n\r", pmmngr_get_memory_size ()); | ||||
|       cprintf ("Total blocks: %#0F%u      %#07Used: %#0F%u        %#07Free: %#0F%u\n\r", pmmngr_get_block_count (), pmmngr_get_use_block_count (), pmmngr_get_free_block_count ()); | ||||
|       cprintf ("Block size: %#0F%u %#07bytes\n\rPaging is ", pmmngr_get_block_size()); | ||||
|       cprintf ( pmmngr_is_paging() ? "%#0Aenabled%#07.\n\r" : "%#0Cdisabled%#07.\n\r"); | ||||
| } | ||||
|  | ||||
|  | ||||
| void apps_read(const int pn, const char *param[]) | ||||
| { | ||||
|       if (pn <= 1) { | ||||
|             cprintf ("%#0CParameter missing: %#0F[sectorLBA]\n\r"); | ||||
|             return; | ||||
|             } | ||||
|        | ||||
|       cprintf ("Sector read, located at address %#0F0x%x.\n\r", i86_read_sector ((unsigned*) 0x7E00, 0, atoi(param[1]))); | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										26
									
								
								SysCore/shell/compile.bat
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								SysCore/shell/compile.bat
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| @echo off | ||||
|  | ||||
| rem NASM and DJGPP executable paths: | ||||
| set nasm_path=C:\nasm | ||||
| set djgpp_path=C:\DJGPP\bin | ||||
| set objpath=..\objects | ||||
| set incpath=../include | ||||
|  | ||||
| @echo Building CTA Shell... | ||||
|  | ||||
| del %objpath%\shell.o | ||||
|  | ||||
| goto build | ||||
| :error | ||||
|       @echo. | ||||
|       @echo There have been build errors. Building halted. | ||||
|       @pause | ||||
|       exit | ||||
|  | ||||
| :build | ||||
|       @echo       * Compiling ... | ||||
|       %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/shell.o shell.c | ||||
|  | ||||
|  | ||||
| :check | ||||
|       if not exist %objpath%\shell.o goto error | ||||
| @@ -1,82 +1,52 @@ | ||||
| #include <conio.h> | ||||
| #include <hal.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include "../memory/mmngr_ph.h" | ||||
| #include "apps.h" | ||||
|  | ||||
| void get_str(char *str, int len) | ||||
| { | ||||
|       kb_key alpha; | ||||
|  | ||||
|       int i; | ||||
|       for (i = 0; i<len-1 ; i++) { | ||||
|             text_mode_cursor(cursor_x, cursor_y); | ||||
|             alpha = getkey(); | ||||
|             switch (alpha.character) { | ||||
|                   case 0x00: --i; break;                    // Ignore null characters | ||||
|                   case 0x7F: --i; break; | ||||
|                   case '\b':                                // Backspace | ||||
|                         if (i>0) {                          // Only backspace our string | ||||
|                               if (--cursor_x < 0) {         // Begin of row - 1 = End of previous row | ||||
|                                     cursor_x = 79; cursor_y--; | ||||
|                               } | ||||
|                               putc_pos(cursor_x, cursor_y, 0); | ||||
|                               str[--i] = 0; | ||||
|                         } | ||||
|                         i--; break; | ||||
|                          | ||||
|                   case '\n': str[i]=0; putc('\n'); return; | ||||
|                          | ||||
|                   default: putc(alpha.character); | ||||
|                         str[i] = alpha.character; | ||||
|                         str[i+1] = 0; | ||||
|                         break; | ||||
|                   } | ||||
|       } | ||||
| } | ||||
|  | ||||
|  | ||||
| void shell() | ||||
| { | ||||
|       apps_osver(); | ||||
|       char str[256]; | ||||
| 	char* param[16]; | ||||
|       int i, len, params=0; | ||||
|  | ||||
|       //clrscr(); | ||||
|        | ||||
|  | ||||
|        | ||||
|       for (;;) { | ||||
|             puts("\n] "); | ||||
|             get_str(str, 256); | ||||
|             cprintf("%#0A\n] "); | ||||
|             cgets(str, 256); | ||||
|             cprintf("\n\r"); | ||||
|  | ||||
| 			len = strlen(str); | ||||
|             len = strlen(str); | ||||
|  | ||||
| 			// Ignore spaces in front of command | ||||
| 			i=0; params = 0; | ||||
| 			while (str[i] == ' ') i++; | ||||
| 			param[params] = str+i; params++; i++;  // Parameter 0 = app itself | ||||
|             // Ignore spaces in front of command | ||||
|             i=0; params = 0; | ||||
|             while (str[i] == ' ') i++; | ||||
|             param[params] = str+i; params++; i++;  // Parameter 0 = app itself | ||||
|  | ||||
|  | ||||
| 			for (; i < len && params<16; i++) { | ||||
| 				if (str[i] == ' ') str[i]=0; | ||||
|             for (; i < len && params<16; i++) { | ||||
|                     if (str[i] == ' ') str[i]=0; | ||||
|  | ||||
| 				if (str[i] != 0 && str[i-1]==0) { | ||||
| 					param[params] = str+i; params++; | ||||
| 				} | ||||
|                     if (str[i] != 0 && str[i-1]==0) { | ||||
|                             param[params] = str+i; params++; | ||||
|                     } | ||||
|             } | ||||
|  | ||||
|             for (i = 0; strcmp(apps_lst[i], param[0])!=0 && i<apps_count; i++); | ||||
|             switch (i) { | ||||
|                   case 0: puts("You must enter a command!\n"); break; | ||||
|                   case 0: cprintf("%#0CYou must enter a command!\n\r"); break; | ||||
|                   case 1: reboot(); | ||||
|                   case 2: apps_osver(); break; | ||||
|                   case 3: apps_time(); break; | ||||
|                   case 4: apps_place(); break; | ||||
|                   case 5: apps_clrscr(); break; | ||||
|                   case 6: apps_memory(params, (const char**)param); break; | ||||
|                   case 6: apps_dump(params, (const char**)param); break; | ||||
|                   case 7: apps_help(params, (const char**)param); break; | ||||
|                   case 8: puts((char*)get_cpu_vender()); break; | ||||
|                   case 8: cprintf("%#0A%s\n\r", (char*)get_cpu_vender()); break; | ||||
|                   case 9: apps_memory_status(); break; | ||||
|                   default: puts("Invalid function: "); puts(param[0]);  | ||||
| 					  putc('\n'); | ||||
|                   case 10: apps_read (params, (const char**)param); break; | ||||
|                   default: cprintf("%#0CInvalid function: %s\n\r", param[0]); | ||||
| 					  break; | ||||
|             } | ||||
|       } | ||||
|   | ||||
							
								
								
									
										165
									
								
								SysCore/video/color/color.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										165
									
								
								SysCore/video/color/color.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,165 @@ | ||||
| #include <color.h> | ||||
| #include <stdlib.h> | ||||
|  | ||||
| RGBColor RGBColors_4bpp[] = {{0, 0, 0},      // 00 Black | ||||
|                             {0, 0, 127},    // 01 Dark Blue | ||||
|                             {0, 127, 0},    // 02 Dark Green | ||||
|                             {0, 127, 127},  // 03 Dark Cyan | ||||
|                             {127, 0, 0},    // 04 Dark Red | ||||
|                             {127, 0, 127},  // 05 Dark Magenta | ||||
|                             {127, 127, 0},  // 06 Dark Yellow | ||||
|                             {192, 192, 192},// 07 Light Gray | ||||
|                             {127, 127, 127},// 08 Dark Gray | ||||
|                             {0, 0, 255},    // 09 Blue | ||||
|                             {0, 255, 0},    // 10 Green | ||||
|                             {0, 255, 255},  // 11 Cyan | ||||
|                             {255, 0, 0},    // 12 Red | ||||
|                             {255, 0, 255},  // 13 Magenta | ||||
|                             {255, 255, 0},  // 14 Yellow | ||||
|                             {255, 255, 255} // 15 White | ||||
| }; | ||||
|  | ||||
|  | ||||
| RGBColor Convert_1bpp_to_RGB(Color_1Bpp c) | ||||
| { | ||||
|     unsigned char t = (c) ? 0xFF : 0x00; | ||||
|     RGBColor temp = {t, t, t}; | ||||
|     return temp; | ||||
| } | ||||
|  | ||||
| RGBColor Convert_4bpp_to_RGB(Color_4Bpp c) | ||||
| { | ||||
|     return RGBColors_4bpp[c]; | ||||
| } | ||||
|  | ||||
| RGBColor Convert_6bpp_to_RGB(Color_6Bpp c) | ||||
| { | ||||
|     unsigned char R, G, B; | ||||
|     R = (unsigned char) ((unsigned)((c & 0x30)>>4) * 255 / 3 ); | ||||
|     G = (unsigned char) ((unsigned)((c & 0x0C)>>2) * 255 / 3 ); | ||||
|     B = (unsigned char) ((unsigned) (c & 0x03) * 255 / 3 ); | ||||
|     RGBColor ret = {R, G, B}; | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| RGBColor Convert_8bpp_to_RGB(Color_8Bpp c) | ||||
| { | ||||
|     unsigned char R, G, B; | ||||
|     R = (unsigned char) ((unsigned)((c & 0xE0)>>5) * 255 / 7 ); | ||||
|     G = (unsigned char) ((unsigned)((c & 0x1C)>>2) * 255 / 7 ); | ||||
|     B = (unsigned char) ((unsigned) (c & 0x03) * 255 / 3 ); | ||||
|     RGBColor ret = {R, G, B}; | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| RGBColor Convert_15bpp_to_RGB(Color_15Bpp c) | ||||
| { | ||||
|     unsigned char R, G, B; | ||||
|     R = (unsigned char) ((unsigned)((c & 0x7C00)>>10) * 255 / 31 ); | ||||
|     G = (unsigned char) ((unsigned)((c & 0x03E0)>>5) * 255 / 31 ); | ||||
|     B = (unsigned char) ((unsigned) (c & 0x001F) * 255 / 31 ); | ||||
|     RGBColor ret = {R, G, B}; | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| RGBColor Convert_16bpp_to_RGB(Color_16Bpp c) | ||||
| { | ||||
|     unsigned char R, G, B; | ||||
|     R = (unsigned char) ((unsigned)((c & 0xF800)>>11) * 255 / 31 ); | ||||
|     G = (unsigned char) ((unsigned)((c & 0x07E0)>>5) * 255 / 63 ); | ||||
|     B = (unsigned char) ((unsigned) (c & 0x001F) * 255 / 31 ); | ||||
|     RGBColor ret = {R, G, B}; | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| RGBColor Convert_18bpp_to_RGB(Color_18Bpp c) | ||||
| { | ||||
|     unsigned char R, G, B; | ||||
|     R = (unsigned char) ((unsigned)(c.R) * 255 / 0x3F ); | ||||
|     G = (unsigned char) ((unsigned)(c.G) * 255 / 0x3F); | ||||
|     B = (unsigned char) ((unsigned)(c.B) * 255 / 0x3F); | ||||
|     RGBColor ret = {R, G, B}; | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| RGBColor Convert_24bpp_to_RGB(Color_24Bpp c) | ||||
| { | ||||
|     return c; | ||||
| } | ||||
|  | ||||
|  | ||||
| Color_1Bpp Convert_RGB_to_1bpp(RGBColor c) | ||||
| { | ||||
|     if (((unsigned)c.R + (unsigned)c.G + (unsigned)c.B) / 3 >= 128) return 1; | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| Color_4Bpp Convert_RGB_to_4bpp(RGBColor c) | ||||
| { | ||||
|     int i; int minim = 0xFFFF; int index = 0; | ||||
|     int R, G, B; | ||||
|  | ||||
|     for (i = 0; i < 16; i++) | ||||
|     { | ||||
|         R = (int)(c.R) - (int)(RGBColors_4bpp[i].R); | ||||
|         G = (int)(c.G) - (int)(RGBColors_4bpp[i].G); | ||||
|         B = (int)(c.B) - (int)(RGBColors_4bpp[i].B); | ||||
|  | ||||
|         R = abs(R) + abs(G) + abs(B); | ||||
|         if (R <= minim) { | ||||
|             minim = R; index = i; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return index; | ||||
| } | ||||
|  | ||||
| Color_6Bpp Convert_RGB_to_6bpp(RGBColor c) | ||||
| { | ||||
|     Color_6Bpp temp = 0; unsigned tmp; | ||||
|     tmp = (unsigned)(c.R) * 3 / 255; temp |= (tmp & 0x03) << 4; | ||||
|     tmp = (unsigned)(c.G) * 3 / 255; temp |= (tmp & 0x03) << 2; | ||||
|     tmp = (unsigned)(c.B) * 3 / 255; temp |= (tmp & 0x03); | ||||
|     return temp; | ||||
| } | ||||
|  | ||||
| Color_8Bpp Convert_RGB_to_8bpp(RGBColor c) | ||||
| { | ||||
|     Color_8Bpp temp = 0; unsigned tmp; | ||||
|     tmp = (unsigned)(c.R) * 7 / 255; temp |= (tmp & 0x07) << 5; | ||||
|     tmp = (unsigned)(c.G) * 7 / 255; temp |= (tmp & 0x07) << 2; | ||||
|     tmp = (unsigned)(c.B) * 3 / 255; temp |= (tmp & 0x03); | ||||
|     return temp; | ||||
| } | ||||
|  | ||||
| Color_15Bpp Convert_RGB_to_15bpp(RGBColor c) | ||||
| { | ||||
|     Color_15Bpp temp = 0; unsigned tmp; | ||||
|     tmp = (unsigned)(c.R) * 0x1F / 255; temp |= (tmp & 0x1F) << 10; | ||||
|     tmp = (unsigned)(c.G) * 0x1F / 255; temp |= (tmp & 0x1F) << 5; | ||||
|     tmp = (unsigned)(c.B) * 0x1F / 255; temp |= (tmp & 0x1F); | ||||
|     return temp; | ||||
| } | ||||
|  | ||||
| Color_16Bpp Convert_RGB_to_16bpp(RGBColor c) | ||||
| { | ||||
|     Color_16Bpp temp = 0; unsigned tmp; | ||||
|     tmp = (unsigned)(c.R) * 0x1F / 255; temp |= (tmp & 0x1F) << 11; | ||||
|     tmp = (unsigned)(c.G) * 0x3F / 255; temp |= (tmp & 0x3F) << 5; | ||||
|     tmp = (unsigned)(c.B) * 0x1F / 255; temp |= (tmp & 0x1F); | ||||
|     return temp; | ||||
| } | ||||
|  | ||||
| Color_18Bpp Convert_RGB_to_18bpp(RGBColor c) | ||||
| { | ||||
|     Color_18Bpp temp; unsigned tmp; | ||||
|     tmp = (unsigned)(c.R) * 0x3F / 255; temp.R = (unsigned char)tmp; | ||||
|     tmp = (unsigned)(c.G) * 0x3F / 255; temp.G = (unsigned char)tmp; | ||||
|     tmp = (unsigned)(c.B) * 0x3F / 255; temp.B = (unsigned char)tmp; | ||||
|     return temp; | ||||
| } | ||||
|  | ||||
| Color_24Bpp Convert_RGB_to_24bpp(RGBColor c) | ||||
| { | ||||
|     return c; | ||||
| } | ||||
							
								
								
									
										66
									
								
								SysCore/video/color/color.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								SysCore/video/color/color.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | ||||
| #ifndef __COLOR__H__ | ||||
| #define __COLOR__H__ | ||||
|  | ||||
| /**RGB color structure.*/ | ||||
| typedef struct { | ||||
|     unsigned char R,G,B; | ||||
| } RGBColor; | ||||
|  | ||||
| /**\Monochrome (black and white)*/ | ||||
| typedef bool            Color_1Bpp; | ||||
|  | ||||
| /**CGA 2 bits per pixel indexed color.\n\n\Notes: Cannot be converted to/from RGB.*/ | ||||
| typedef unsigned char   Color_2Bpp; | ||||
|  | ||||
| /**16 color VGA. | ||||
|  * \n\n\Format: Uses 1-1-1 bit format, highest bit is intensity. | ||||
|  * \n\n\Notes: Unused bits are ignored (should be 0).*/ | ||||
| typedef unsigned char   Color_4Bpp; | ||||
|  | ||||
| /**64 color EGA. | ||||
|  * \n\n\Format: Uses 2-2-2 bit format. | ||||
|  * \n\n\Notes: High 2 bits are ignored (should be 0).*/ | ||||
| typedef unsigned char   Color_6Bpp; | ||||
|  | ||||
| /**256 color VGA. | ||||
|  * \n\n\Format: Uses 3-3-2 bit format | ||||
|  * \n\n\Notes: The palette must be changed before usable.*/ | ||||
| typedef unsigned char   Color_8Bpp; | ||||
|  | ||||
| /**SVGA Highcolor palette. | ||||
|  * \n\n\Format: Uses 5-5-5 bit format. | ||||
|  * \n\n\Notes: Unused high bit is ignored (should be 0).*/ | ||||
| typedef unsigned short  Color_15Bpp; | ||||
|  | ||||
| /**SVGA Highcolor palette. | ||||
|  * \n\n\Format: Uses 5-6-5 bit format.*/ | ||||
| typedef unsigned short  Color_16Bpp; | ||||
|  | ||||
| /**VGA 18-bit RGB | ||||
|  * \n\n\Format: Uses the RGBColor structure, with the R, G and B components. | ||||
|  * \n\n\Notes: High 2 bits of each component are ignored, should be 0.*/ | ||||
| typedef RGBColor        Color_18Bpp; | ||||
|  | ||||
| /**24-bit Truecolor | ||||
|  * \n\n\Format: Uses the RGBColor structure, with the R, G and B components.*/ | ||||
| typedef RGBColor        Color_24Bpp; | ||||
|  | ||||
| /**Few functions to convert values from one format to another.*/ | ||||
| extern RGBColor Convert_1bpp_to_RGB(Color_1Bpp c); | ||||
| extern RGBColor Convert_4bpp_to_RGB(Color_4Bpp c); | ||||
| extern RGBColor Convert_6bpp_to_RGB(Color_6Bpp c); | ||||
| extern RGBColor Convert_8bpp_to_RGB(Color_8Bpp c); | ||||
| extern RGBColor Convert_15bpp_to_RGB(Color_15Bpp c); | ||||
| extern RGBColor Convert_16bpp_to_RGB(Color_16Bpp c); | ||||
| extern RGBColor Convert_18bpp_to_RGB(Color_18Bpp c); | ||||
| extern RGBColor Convert_24bpp_to_RGB(Color_24Bpp c); | ||||
| extern Color_1Bpp Convert_RGB_to_1bpp(RGBColor c); | ||||
| extern Color_4Bpp Convert_RGB_to_4bpp(RGBColor c); | ||||
| extern Color_6Bpp Convert_RGB_to_6bpp(RGBColor c); | ||||
| extern Color_8Bpp Convert_RGB_to_8bpp(RGBColor c); | ||||
| extern Color_15Bpp Convert_RGB_to_15bpp(RGBColor c); | ||||
| extern Color_16Bpp Convert_RGB_to_16bpp(RGBColor c); | ||||
| extern Color_18Bpp Convert_RGB_to_18bpp(RGBColor c); | ||||
| extern Color_24Bpp Convert_RGB_to_24bpp(RGBColor c); | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										26
									
								
								SysCore/video/compile.bat
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								SysCore/video/compile.bat
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| @echo off | ||||
|  | ||||
| rem NASM and DJGPP executable paths: | ||||
| set nasm_path=C:\nasm | ||||
| set djgpp_path=C:\DJGPP\bin | ||||
| set objpath=..\objects | ||||
| set incpath=../include | ||||
|  | ||||
| @echo Building Video Drivers... | ||||
|  | ||||
| del %objpath%\video\vga03h.o | ||||
|  | ||||
| goto build | ||||
| :error | ||||
|       @echo. | ||||
|       @echo There have been build errors. Building halted. | ||||
|       @pause | ||||
|       exit | ||||
|  | ||||
| :build | ||||
|       @echo       * Compiling Text Mode 0x03 video driver ... | ||||
|       %djgpp_path%\gcc.exe -Wall -O -fstrength-reduce -fomit-frame-pointer -nostdinc -fno-builtin -I%incpath% -c -o %objpath%/video/vga03h.o vga03h.c | ||||
|  | ||||
|  | ||||
| :check | ||||
|       if not exist %objpath%\video\vga03h.o goto error | ||||
							
								
								
									
										37
									
								
								SysCore/video/vga.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								SysCore/video/vga.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | ||||
| #ifndef __VGA__H__ | ||||
| #define __VGA__H__ | ||||
|  | ||||
| typedef struct { | ||||
|     enum MODE_TYPES { | ||||
|         TextMode = 0, | ||||
|         GraphicsMode = 1 | ||||
|     }; | ||||
|     /**Defines the mode returned by BIOS int 0x10, ah = 0xF*/ | ||||
|     unsigned char Mode; | ||||
|     /**Text mode or Graphic mode (defined in MODE_TYPES enumeration)*/ | ||||
|     unsigned char ModeType; | ||||
|  | ||||
|     /**Screen size (characters in text modes, pixels in graphic modes)*/ | ||||
|     unsigned Width, Height; | ||||
|  | ||||
|     /**Bits per pixel*/ | ||||
|     unsigned bpp; | ||||
|  | ||||
|     /**Pointer to a function that sets the cursor position*/ | ||||
|     void (*SetCursor) (int wherex, int wherey); | ||||
|     /**Pointer to a function that prints an ascii character in a specified position*/ | ||||
|     void (*PutChar) (int wherex, int wherey, unsigned char character); | ||||
|     /**Pointer to a function that returns the ascii character in the specified position*/ | ||||
|     unsigned char (*GetChar) (int wherex, int wherey); | ||||
|  | ||||
|     /**Pointer to a function which plots a pixel on the screen. Should be set NULL in text modes. | ||||
|      \nColor is a void pointer, to ensure compatibility with different colors.*/ | ||||
|     void (*PutPixel) (int wherex, int wherey, void* color); | ||||
|  | ||||
|     /**Pointer to a function which returns the color of a pixel on the screen. Should be set NULL in text modes. | ||||
|      \nReturn is a void pointer, to ensure compatibility with different colors.*/ | ||||
|     void* (*GetPixel) (int wherex, int wherey); | ||||
|      | ||||
| } VideoMode; | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										30
									
								
								SysCore/video/vga03h.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								SysCore/video/vga03h.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| //#include "vga.h" | ||||
| #include <conio.h> | ||||
| #include <system.h> | ||||
|  | ||||
| unsigned char* TextVideoRam = (unsigned char*)0xB8000; | ||||
|  | ||||
| void vga03h_cursor(int x, int y) | ||||
| { | ||||
|       unsigned temp = y*80 + x; | ||||
|  | ||||
|       outportb (0x3D4, 14); | ||||
|       outportb (0x3D5, temp >> 8); | ||||
|       outportb (0x3D4, 15); | ||||
|       outportb (0x3D5, temp); | ||||
| } | ||||
|  | ||||
| void           vga03h_putc     (int x, int y, unsigned char c)  { TextVideoRam[2*(y*80+x)] = c;    } | ||||
| unsigned char  vga03h_getc     (int x, int y)                   { return TextVideoRam[2*(y*80+x)]; } | ||||
| void           vga03h_putcolor (int x, int y, unsigned char c)  { TextVideoRam[2*(y*80+x)+1] = c;  } | ||||
| unsigned char  vga03h_getcolor (int x, int y)                   { return TextVideoRam[2*(y*80+x)+1]; } | ||||
|  | ||||
| void vga03h_install() | ||||
| { | ||||
|       ConsoleScreen screen = { | ||||
|             80, 25, 0x07, vga03h_cursor, vga03h_putc, vga03h_getc, | ||||
|             vga03h_putcolor, vga03h_getcolor}; | ||||
|              | ||||
|       ConsoleInstall (screen); | ||||
|       clrscr(); | ||||
| } | ||||
							
								
								
									
										7
									
								
								SysCore/video/vga03h.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								SysCore/video/vga03h.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| #ifndef __DEFAULT__TEXT__MODE__H__ | ||||
| #define __DEFAULT__TEXT__MODE__H__ | ||||
|  | ||||
| void vga03h_install(); | ||||
|  | ||||
|  | ||||
| #endif | ||||
		Reference in New Issue
	
	Block a user