当我们写一些外设驱动,或者内核模块,经常会使用ioremap函数来映射寄存器io地址,来访问io空间,在ioremap函数的实现内部会对传入的参数进行判断,如果地址不属于io空间,则会内核会报Warnig。
从函数名字我们也可以看得出来,既然函数叫io remap,那么映射的地址空间必须是io的物理地址,所以如果映射的地址落在了ram地址空间,内核就会报warning!如下面的log
内核报warning的日志:
[ 2.536156] ------------[ cut here ]------------
[ 2.540766] WARNING: CPU: 0 PID: 1 at __ioremap_caller+0xd0/0xd8
[ 2.546759] Modules linked in:
[ 2.549804]
[ 2.551286] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 4.9.30-rt19-EMBSYS-CGEL-6.1.R3-g51292b3-dirty #26
[ 2.560664] Hardware name: MCS2 (DT)
[ 2.564227] task: ffffffc2d7c98d00 task.stack: ffffffc2d7c9c000
[ 2.570134] PC is at __ioremap_caller+0xd0/0xd8
[ 2.574652] LR is at __ioremap_caller+0x54/0xd8
[ 2.579170] pc : [<ffffff80080964e8>] l