汇编------双向循环链表

.section .rodata
	.LC0:.string "%d "


//struct node
//{
//	int value;
//	struct node *pre;
//	struct node *next;
//}
//
//
//struct list
//{
//	struct node nod;
//	int count;
//}

.section .text
//void init(struct list *ls);
init:
	pushl %ebp
	movl %esp,%ebp
		
	movl 8(%ebp),%eax
	movl $0,(%eax)
	movl %eax,4(%eax)
	movl %eax,8(%eax)
	movl $0,12(%eax)	
	
	movl %ebp,%esp
	popl %ebp
	ret

//void add(struct list *ls,int val)
add:
	pushl %ebp
	movl %esp,%ebp
	
	pushl $12
	call malloc
	addl $4,%esp
	
	movl 12(%ebp),%ecx
	movl %ecx,(%eax)
	
	movl 8(%ebp),%ecx
	movl 4(%ecx),%edx

	// edx   eax  ecx	
	movl %edx,4(%eax)
	movl %ecx,8(%eax)
	
	movl %eax,4(%ecx)
	movl %eax,8(%edx)
	
	addl $1,16(%eax)
	
	movl %ebp,%esp
	popl %ebp
	ret

//void print(list *ls)
print:
	pushl %ebp
	movl %esp,%ebp
	pushl %esi
	pushl %edi
	
	movl 8(%ebp),%eax
	movl %eax,%esi
	movl 8(%eax),%edi
	
	jmp .L1
.L2:
	pushl (%edi)
	pushl $.LC0
	call printf
	addl $8,%esp
	
	movl 8(%edi),%edi
.L1:
	cmpl %esi,%edi
	jne .L2
	
	pushl $'\n'
	call putchar
	addl $4,%esp
	
	popl %edi
	popl %esi
	movl %ebp,%esp
	popl %ebp
	ret


//struct node *get(list *ls,int idx)
get:
	pushl %ebp
	movl %esp,%ebp
	
	movl 12(%ebp),%eax
	movl 8(%ebp),%edx
	movl 12(%edx),%edx
	cmpl $0,%eax
	jl .L3
	cmpl %edx,%eax
	jge .L4
.L3:
	pushl $1
	call exit
.L4:
	
	movl 8(%ebp),%eax
	movl 8(%eax),%eax
	
	movl 12(%ebp),%edx
	jmp .L5
.L6:
	movl 8(%eax),%eax
	subl $1,%edx
.L5:
	cmpl $0,%edx
	jne .L6
	
	movl %ebp,%esp
	popl %ebp
	ret

//void del(list *ls,int idx)
del:
	pushl %ebp
	movl %esp,%ebp
	pushl %ebx
	
	pushl 12(%ebp)
	pushl 8(%ebp)
	call get
	addl $8,%esp
	
	//ecx eax edx
	movl 4(%eax),%ecx
	movl 8(%eax),%edx
	
	movl 8(%eax),%ebx
	movl %ebx,8(%ecx)
	
	movl 4(%eax),%ebx
	movl %ebx,4(%edx)
	
	movl 8(%ebp),%eax
	subl $1,16(%eax)
	
	popl %ebx	
	movl %ebp,%esp
	popl %ebp
	ret


.global main
main:
	pushl %ebp
	movl %esp,%ebp
	subl $16,%esp
	
	leal -16(%ebp),%eax
	pushl %eax
	call init
	addl $4,%esp
	
	pushl $11
	leal -16(%ebp),%eax
	pushl %eax
	call add
	addl $8,%esp
	
	
	pushl $22
	leal -16(%ebp),%eax
	pushl %eax
	call add
	addl $8,%esp
	
	
	pushl $33
	leal -16(%ebp),%eax
	pushl %eax
	call add
	addl $8,%esp
	

	pushl $2
	leal -16(%ebp),%eax
	pushl %eax
	call del
	addl $8,%esp
				
	
	leal -16(%ebp),%eax
	pushl %eax
	call print
	addl $4,%esp
	
	
		
	movl %ebp,%esp
	popl %ebp
	ret


 

上一篇:【汇编语言与计算机系统结构笔记05】汇编的系统结构,从C代码生产汇编代码,一个具体的、经典的数据传送指令(mov)实例与分析


下一篇:【汇编语言与计算机系统结构笔记06】地址计算指令,lea / leal,x86-32与x86-64下的swap对比,汇编的格式对比(Intel/Microsoft Differs from GAS)