BBBc
asmlinkage强调了系统调用从堆栈中获取参数,摒弃从寄存器获取参数这种高效高速的办法,在syscall时,参数都是通过寄存器传递的,但是在内核态中,参数是从栈中读取的,所以将寄存器的copy压栈,既保证了用户态时寄存器读取参数的标准,也保证了内核态的参数传递标准。
系统调用时,即发生了用户态向内核态的切换,此时需要将用户态的esp等栈指针传递进内核态,由于用户栈(级别0)和内核栈(级别3)彼此独立不可见,无法传递函数指针,故不能通过直接将参数压栈这种方法来传递。
BBBc
asmlinkage强调了系统调用从堆栈中获取参数,摒弃从寄存器获取参数这种高效高速的办法,在syscall时,参数都是通过寄存器传递的,但是在内核态中,参数是从栈中读取的,所以将寄存器的copy压栈,既保证了用户态时寄存器读取参数的标准,也保证了内核态的参数传递标准。
系统调用时,即发生了用户态向内核态的切换,此时需要将用户态的esp等栈指针传递进内核态,由于用户栈(级别0)和内核栈(级别3)彼此独立不可见,无法传递函数指针,故不能通过直接将参数压栈这种方法来传递。