Merge branch 'feature/kernel-size-awareness' into 'develop'
Kernel Size Awareness See merge request spexeah/asuro!32
This commit is contained in:
		| @@ -2,7 +2,7 @@ ENTRY(loader) | |||||||
| SECTIONS | SECTIONS | ||||||
| { | { | ||||||
|   . = 0xC0100000; |   . = 0xC0100000; | ||||||
|  |   kernel_start = .; | ||||||
|   .text : AT(ADDR(.text) - 0xC0000000) |   .text : AT(ADDR(.text) - 0xC0000000) | ||||||
|   { |   { | ||||||
|     text = .; _text = .; __text = .; |     text = .; _text = .; __text = .; | ||||||
| @@ -33,4 +33,5 @@ SECTIONS | |||||||
|     . = ALIGN(4096); |     . = ALIGN(4096); | ||||||
|   } |   } | ||||||
|   end = .; _end = .; __end = .; |   end = .; _end = .; __end = .; | ||||||
|  |   kernel_end = .; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -143,6 +143,22 @@ type | |||||||
|  |  | ||||||
|     PText = ^Text; |     PText = ^Text; | ||||||
|  |  | ||||||
|  | var | ||||||
|  |   AK_START : uint32; external name 'kernel_start'; | ||||||
|  |   AK_END   : uint32; external name 'kernel_end'; | ||||||
|  |   ASURO_KERNEL_START : uint32; | ||||||
|  |   ASURO_KERNEL_END   : uint32; | ||||||
|  |   ASURO_KERNEL_SIZE  : uint32; | ||||||
|  |  | ||||||
|  | procedure init(); | ||||||
|  |  | ||||||
| implementation | implementation | ||||||
|  |  | ||||||
|  | procedure init(); | ||||||
|  | begin | ||||||
|  |     ASURO_KERNEL_START := uint32(@AK_START); | ||||||
|  |     ASURO_KERNEL_END := uint32(@AK_END); | ||||||
|  |     ASURO_KERNEL_SIZE:= ASURO_KERNEL_END - ASURO_KERNEL_START; | ||||||
|  | end; | ||||||
|  |  | ||||||
| end. | end. | ||||||
|   | |||||||
| @@ -125,6 +125,9 @@ var | |||||||
|    HM              : PHashMap; |    HM              : PHashMap; | ||||||
|     |     | ||||||
| begin | begin | ||||||
|  |      { Init the base system unit } | ||||||
|  |      System.init(); | ||||||
|  |  | ||||||
|      { Serial Init } |      { Serial Init } | ||||||
|      serial.init(); |      serial.init(); | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user