⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tasks.asm

📁 jserv写的orz小内核 有详细的注释
💻 ASM
字号:
		struc s_task.taskID:	resd 1		; 0 - .state:		resb 1.newTick:	resd 1		; need for state=STATE_SLEEP.queue:		resd (MAX_TASKS + 1)	; jiao: msg queue.qFirst:  	resd 1.qLast:		resd 1.s_taskID:	resd 1.s_message:	resd 1.s_dataPtr:	resd 1.s_dataSize:	resd 1.taskPageAddr:	resd 1.taskPages:	resd 1.r_eflags:	resd 1.r_eax:		resd 1.r_ebx:		resd 1.r_ecx:		resd 1.r_edx:		resd 1.r_esi:		resd 1.r_edi:		resd 1.r_ebp:		resd 1.r_esp:		resd 1.r_eip:		resd 1.taskName:	resb (MAX_TASK_NAME + 1).msize:		endstruc;--------------------------------------------------------------------------------------;;;; Some variableskernel_esp	dd 0tasksCount	dd 0currentID	dd 1currentTaskN	dd 0	; currentTaskP	dd 0	; s_task;--------------------------------------------------------------------------------------;;;; OUT: tasks table modifed;;;; MODIFY: EAX, ECX, EBPInitTasks:	mov ecx, MAX_TASKS	mov ebp, tasks	xor eax, eaxInitTasks0:	mov [ebp + s_task.taskID], eax	add ebp, s_task.msize	loop InitTasks0	ret;--------------------------------------------------------------------------------------;;;; IN: EAX = taskBegin, EBX = taskSize, ECX = stackSize, EDX = dataSize, ESI = taskNamePtr;;;; OUT: if (FLAG_C) error(); else {EAX = taskID;};;;; MODIFY: EAX, EBX, ECX, EDX, ESI, EDI, EBPCreateTask:	mov [taskNamePtr], esi	mov [taskBegin], eax	mov [copySize], ebx	add ebx, ecx	add ebx, edx	mov [taskSize], ebx	; taskSize + stackSize + dataSize	mov ebx, [tasksCount]	cmp ebx, MAX_TASKS	jc CreateTask0	stc	retCreateTask0:	mov esi, tasksList	add esi, ebx		; jiao: esi = taskCount	mov ebp, tasks	xor cl, cl	xor edx, edxCreateTask1:	cmp [ebp + s_task.taskID],edx	; jiao: jump to CreateTask2 after last task	jz CreateTask2	add ebp, s_task.msize	inc cl	jmp short CreateTask1	; ( tasksCount < MAX_TASKS).CreateTask2:	mov [ebp + s_task.r_eip], edx	; jiao: all 0	mov [ebp + s_task.r_eax], edx	mov [ebp + s_task.r_ebx], edx	mov [ebp + s_task.r_ecx], edx	mov [ebp + s_task.r_edx], edx	mov [ebp + s_task.r_esi], edx	mov [ebp + s_task.r_edi], edx	mov [ebp + s_task.r_ebp], edx	mov [ebp + s_task.state], BYTE STATE_RUNNING	push esi	push ecx	mov eax, [taskSize]	call SizeToPages	mov [ebp + s_task.taskPages], ecx	push ebp	call AllocPages	pop ebp	pop ecx	pop esi	jnc CreateTask3	stc	retCreateTask3:	mov [esi], cl	inc DWORD [tasksCount]	lea esi,[ebp + s_task.queue]	mov [ebp + s_task.qFirst], esi	mov [ebp + s_task.qLast], esi	mov [ebp + s_task.taskPageAddr], eax	mov eax, [ebp + s_task.taskPages]	imul eax, 0x1000	dec eax	mov [ebp + s_task.r_esp], eax	; jiao: set esp at the highest address	xor eax,eax	; clear ZF	clc		; clear CF	sti		; dirty hack, do it normally with some OR || AND at (*) place	pushfd	cli		; dirty hack, do it normally with some OR || AND at (*) place	pop eax	; (*)	mov [ebp + s_task.r_eflags], eax	; jiao: set eflags	mov esi, [taskBegin]	mov edi, [ebp + s_task.taskPageAddr]	mov ecx, [copySize]	rep movsb	lea edi, [ebp + s_task.taskName]	mov esi, [taskNamePtr]	mov ecx, MAX_TASK_NAMECreateTask4:	lodsb	and al, al	jz CreateTask5	stosb	loop CreateTask4	xor al, alCreateTask5:	stosb	mov eax, [currentID]	mov [ebp + s_task.taskID], eax	inc eax	; EAX!=0 PID	mov [currentID],eax	clc	rettaskBegin	dd 0x12340000taskSize	dd 0x12341000copySize	dd 0x12342000taskNamePtr	dd 0x12343000;--------------------------------------------------------------------------------------; IN: ESI = taskToFindNamePtr; OUT: if (FLAG_C) error(); else {EAX = taskID; EBP = taskP;}; MODIFY: EAX (), EBP (), ECX, EDIFindTaskByName:	mov ecx, [tasksCount]	jecxz FindTaskByName3	mov edi, tasksListFindTaskByName0:	movzx ebp, BYTE [edi]	imul ebp, s_task.msize	add ebp, tasks	push edi	push esi	lea edi, [ebp + s_task.taskName]FindTaskByName1:	mov al, [esi]	or al, [edi]	jz FindTaskByName4	; success	mov al, [esi]	and al, al	jz FindTaskByName2	cmp al,[edi]	jnz FindTaskByName2	mov al, [edi]	and al, al	jz FindTaskByName2	inc esi	inc edi	jmp short FindTaskByName1FindTaskByName2:	pop esi	pop edi	inc edi	loop FindTaskByName0FindTaskByName3:	stc	retFindTaskByName4:	pop esi	pop edi	mov eax, [ebp + s_task.taskID]	clc	ret;--------------------------------------------------------------------------------------;;;; IN: EAX = taskID;;;; OUT: if (FLAG_C) error(); else {EAX = taskN; EBP = taskP;};;;; MODIFY: EAX (), ECX, ESI, EBP ()FindTask:	mov ecx, [tasksCount]	jecxz FindTask1	mov esi, tasksListFindTask0:	movzx ebp, BYTE [esi]	imul ebp, s_task.msize	add ebp, tasks	cmp eax, [ebp + s_task.taskID]	jz FindTask2	inc esi	loop FindTask0FindTask1:	stc	retFindTask2:	mov eax, esi	sub eax, tasksList	clc	ret;--------------------------------------------------------------------------------------;;;; IN: EAX = taskID;;;; OUT: if (FLAG_C) error(); else success();;;;; MODIFY: EAX, ECX, ESI, EDI, {FindTask :: EBP}KillTask:	call FindTask	jnc KillTask0	retKillTask0:	mov ecx, [tasksCount]	dec ecx	sub ecx, eax	jecxz KillTask1	mov edi, tasksList	add edi, eax	mov esi, edi	inc esi	rep movsbKillTask1:	dec DWORD [tasksCount]	mov [ebp + s_task.taskID], DWORD 0	mov eax, [ebp + s_task.taskPageAddr]	mov ecx, [ebp + s_task.taskPages]	call FreePages	; 	clc	ret;--------------------------------------------------------------------------------------tx_NoMoreTasks	db "No more tasks",0Schedule:	mov eax, [tasksCount]	and eax, eax	jnz Schedule0	mov esi, tx_NoMoreTasks	jmp GpFaultSchedule0:	mov eax, [currentTaskN]		; jiao: turn to next task	inc eax	cmp eax, [tasksCount]	jc Schedule1	xor eax, eaxSchedule1:	mov [currentTaskN], eax	add eax, tasksList	movzx eax, BYTE [eax]	imul eax, s_task.msize	add eax, tasks	mov [currentTaskP], eax	mov ebp, eax	mov eax, [ebp + s_task.state]	; jiao: if state == STATE_SENDW || stat == STATE_STOP, turn to next task	cmp eax, STATE_SENDW	jz Schedule0	cmp eax, STATE_STOP	jz Schedule0ScheduleCurr:	cli	mov eax, 0x20	mov [taskRunningTime], eax	mov eax, [ebp + s_task.taskPageAddr]	; jiao: copy base address to task descripter in _GDT	mov [task_code + 2], ax		; base 00..15, jiao: task_code and task_data defined in _GDT(tables.asm)	mov [task_data + 2], ax	shr eax, 0x10	mov [task_code + 4], al		; base 16..23	mov [task_code + 7], ah		; base 24..31	mov [task_data + 4], al		; base 16..23	mov [task_data + 7], ah		; base 24..31	;  > 65535	mov eax, [ebp + s_task.taskPages]	mov [task_code], ax		; limit 00..15	mov [task_data], ax		; limit 00..15	mov [kernel_esp], esp	mov esp, [ebp + s_task.r_esp]	; jiao: set esp and stack segment	mov ax, task_data - _GDT	mov ss, ax	push DWORD [ds:ebp + s_task.r_eflags]	push DWORD (task_code - _GDT)	push DWORD [ds:ebp + s_task.r_eip]	mov eax, [ds:ebp + s_task.r_ebp]	push eax	mov eax, [ds:ebp + s_task.r_eax]	push eax	mov ebx, [ds:ebp + s_task.r_ebx]	mov ecx, [ds:ebp + s_task.r_ecx]	mov edx, [ds:ebp + s_task.r_edx]	mov esi, [ds:ebp + s_task.r_esi]	mov edi, [ds:ebp + s_task.r_edi]	mov ax,task_data - _GDT		; jiao: set data segment	mov ds, ax	mov es, ax	pop eax	pop ebp	iretd	; fly to task

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -