对int、iret和栈的深入理解

我们以一个程序来展开讨论:用7ch中断例程完成loop指令的功能,在屏幕中间显示80个"!"

1.程序框架如下

assume cs:code
code segment
start:
	mov ax,0b800h	;向8086CPU显存的地址
	mov di,160*12	;显示位置
	mov bx,offset s-offset se	;跳转的位移
	mov cx,80	;循环次数
s:
	mov byte ptr es:[di],'!'
	add di,2
	int 7ch	;进入中断处理程序
se:	nop
	mov ax,4c00h
	int 21h

code ends
end start

2.中断处理程序的功能如下:

1)dec cx

2)如果(cx)!=0,转到标号s处执行,否则向下执行

那么如何实现到目的地址s的转移?

1)转移到s显然应设(CS)=s的段地址,(IP)=s的偏移地址

2)那么中断程序如何得到s的段地址和偏移地址?

3)现在知道,可以从栈中直接和间接获得s的段地址和偏移地址,那么如何用他们设置CS:IP?

7c的中断程序如下:

lp:
	push bp
	mov bp,sp
	dec cx
	jcxz lpret
	add [bp+2],bx
lpret:
	pop bp
	iret

这里跟高级语言里面函数调用栈帧很相似,后面我会专门更新一篇介绍函数调用栈帧的文章。

Task stTaskQueue[256]; int iTaskCount = 0; pthread_mutex_t stMutexQueue; pthread_cond_t stCondQueue; pthread_t stThreadAry[cmnDfn_WORKING_PTHREAD_NUMBER]; void* PthreadPoolWorker(void* arg) { Task* pstTask; while(1) { if(pthread_mutex_lock(&stMutexQueue)) { cmn_PrtError("Error in locking mutex"); } while(iTaskCount == 0 && g_iExit == 0) { pthread_cond_wait(&stCondQueue, &stMutexQueue); } if(g_iExit == 1) { pthread_mutex_unlock(&stMutexQueue); break; } pstTask = &stTaskQueue[--iTaskCount]; if(pthread_mutex_unlock(&stMutexQueue)) { cmn_PrtError("Error in unlocking mutex"); } pstTask->task(pstTask->arg); } _Exit: pthread_exit(NULL); } int ThreadPoolSubmit(void* (*task)(void*),void* arg) { int iRet = -1; if(pthread_mutex_lock(&stMutexQueue) != 0) { cmn_PrtError("Error in locking mutex"); } if(iTaskCount >= 256) { pthread_mutex_unlock(&stMutexQueue); cmn_PrtError("Error in queue overflow"); } stTaskQueue[iTaskCount].task = task; stTaskQueue[iTaskCount].arg = arg; iTaskCount++; if(pthread_mutex_unlock(&stMutexQueue) != 0) { cmn_PrtError("Error in unlocking mutex"); } if(pthread_cond_signal(&stCondQueue) < 0) { cmn_PrtError("Error in signaling condition"); } iRet = 0; _Exit: return iRet; } int ThreadPoolInit(void) { int iRet = -1; int iLoopNum; if(pthread_mutex_init(&stMutexQueue, NULL) <0) { cmn_PrtError("Error in initializing mutex"); } if(pthread_cond_init(&stCondQueue, NULL)) { cmn_PrtError("Error in initializing condition"); } for(iLoopNum = 0; iLoopNum < cmnDfn_WORKING_PTHREAD_NUMBER; iLoopNum++) { if(pthread_create(&stThreadAry[iLoopNum], NULL, PthreadPoolWorker, NULL) < 0) { cmn_PrtError("Error in creating thread"); } } iRet = 0; _Exit: return iRet; } int ThreadPoolDestroy(void) { int iRet = -1; int iLoopNum; if(pthread_mutex_lock(&stMutexQueue)!= 0) { cmn_PrtError("Error in locking mutex"); } g_iExit = 1; if(pthread_cond_broadcast(&stCondQueue) < 0) { cmn_PrtError("Error in broadcasting condition"); } if(pthread_mutex_unlock(&stMutexQueue)!= 0) { cmn_PrtError("Error in unlocking mutex"); } for(iLoopNum = 0; iLoopNum < cmnDfn_WORKING_PTHREAD_NUMBER; iLoopNum++) { if(pthread_join(stThreadAry[iLoopNum], NULL)) { cmn_PrtError("Error in joining thread"); } } if(pthread_mutex_destroy(&stMutexQueue)!= 0) { cmn_PrtError("Error in destroying mutex"); } if(pthread_cond_destroy(&stCondQueue)!= 0) { cmn_PrtError("Error in destroying condition"); } iRet = 0; _Exit: return iRet; }详细解释线程池
最新发布
03-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值