|
|
ret_sp macro dummy
' {& N* j/ I* D, z local llll, lll 5 k. r4 R, [- R( l
even/ }( `) n* D j+ n g
mov sp, offset cs:lll 0 O* T! L/ \7 \
jmp dummy
( H' G" T( {6 Flll:
! S# C x3 y: m% T) g R& G dw offset cs:llll ; return address0 v' x# N* `# T* X( h
llll:0 c) `+ r7 o. f2 X4 X! P7 n
endm
/ m& E# Z: `) ]! @# z- C; x
( W- C4 W7 P, Q& s: [关于ret_sp这个宏我有一点没有搞明白
4 |% B) X# S! v假设lll的地址为200h,那么mov sp, offset cs:lll这条语句就是把200h赋给了SP,而jmp dummy中的dummy函数最后的ret语句相当于直接把sp pop给了IP,也就是说dummy执行完以后,IP直接回到了lll处,那么还要llll这个标号干什么呢?; Y8 ?2 R! m9 w! L$ G' M5 J8 ~
为什么不能直接写成:# L% z/ W, H' J4 q Y; A! t" v
ret_sp macro dummy - v& ?+ \5 O4 k- }1 R0 i1 v" b
local lll
5 T/ L, j0 v# ~2 ^0 V/ T- D" L even
' {# y. o$ K Q mov sp, offset cs:lll
/ @3 _9 _% B! S% l" { jmp dummy8 D u$ n- w0 Q0 Q
lll:
' U3 @: W( m* y/ S$ Z, p2 ~7 fendm
' i$ Y* J) D' d4 {
* J" K4 O, w/ m2 E0 j" g% C请知道的指点一下,谢谢! |
|