内核运行之前访问IO

如果要在内核运行之前访问CPU的某些IO端口,直接使用指针方式定义寄存器进行操作即可。例如,在解压内核的时候喂狗,通过操作IO进行,可以这样操作:

在arch/arm/boot/compressed/misc.c文件:
 
    307     arch_decomp_setup();
    308
    309     makecrc();
    310     *((volatile unsigned long *)0x40E00054) &= (~(3<<28)); //ABING GPAF0_L
    311     *((volatile unsigned long *)0x40E0001C) = (1<<14); //ABING GPDR0
    312     *((volatile unsigned long *)0x40E00024) = (1<<14); //ABING GPCR0
    313     putstr("Uncompressing Linux...");
    314     *((volatile unsigned long *)0x40E00018) = (1<<14); //ABING GPSR0
    315     gunzip();
    316     *((volatile unsigned long *)0x40E00024) = (1<<14); //ABING GPCR0
    317     putstr(" done, booting the kernel.\n");
    318     return output_ptr;
 
 
 
 
参考include/asm-arm/arch-pxa/uncompress.h文件访问串口的代码:
  12#define FFUART          ((volatile unsigned long *)0x40100000)
  13#define BTUART          ((volatile unsigned long *)0x40200000)
  14#define STUART          ((volatile unsigned long *)0x40700000)
  15
  16#define UART            FFUART
  17
  18
  19static __inline__ void putc(char c)
  20{
  21        while (!(UART[5] & 0x20));
  22        UART[0] = c;
  23}
  24
  25/*
  26 * This does not append a newline
  27 */
  28static void putstr(const char *s)
  29{
  30        while (*s) {
  31                putc(*s);
  32                if (*s == '\n')
  33                        putc('\r');
  34                s++;
  35        }
  36}
 
   
 
   
可以这样定义:
#define __raw_readl(a)    (*(volatile unsigned int *)(a))
#define __raw_writel(v,a) (*(volatile unsigned int *)(a) = (v))
#define __raw_readw(a)    (*(volatile unsigned short *)(a))
#define __raw_writew(v,a) (*(volatile unsigned short *)(a) = (v))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 对于您的问题,我可以回答是的,进程访问内存时需要内核介入。内核扮演着操作系统核心的角色,处理系统级别的任务,并确保进程正常运行。当进程需要访问内存时,内核会检查内存是否存在,如果存在则将数据传输给进程。 ### 回答2: 是的,进程访问内存时需要内核介入。 在操作系统中,内核负责管理和控制计算机资源,包括内存。进程在执行过程中需要访问内存,进行读取或写入的操作。然而,访问内存是受限的,因为每个进程只能访问其分配的内存空间,也无法直接访问其他进程的内存。 因此,当一个进程需要访问内存时,它需要通过系统调用向内核发起请求。系统调用是操作系统提供给进程的接口,用于请求特权操作,如访问内存、IO等。进程通过系统调用告诉内核需要什么样的内存操作,比如读取某个地址的值或者写入某个值。内核会检查进程的请求是否合法,并根据请求的类型进行相应的处理。 当进程需要读取内存时,内核会检查该进程是否有对应地址的访问权限,如果有,则将对应的内存数据返回给进程;如果没有权限,则返回错误。当进程需要写入内存时,内核会先检查内存是否存在,是否有可写权限,并进行相应的操作。 此外,内核还负责管理分配和回收内存,确保不同的进程之间互不干扰。当进程需要分配内存时,内核会分配一段合适的内存空间给进程,并记录其地址、大小等信息。当进程结束或释放内存时,内核会回收分配给该进程的内存,并将其重新分配给其他进程使用。 因此,进程访问内存时必须经过内核的介入,通过系统调用进行权限检查和操作,以保证进程之间的安全和互不干扰。 ### 回答3: 是的,进程在访问内存时通常需要内核的介入。 内存访问是指进程对内存中数据的读取或写入操作。在现代操作系统中,每个进程都有自己的虚拟地址空间,而这些虚拟地址需要通过内核的支持映射到物理内存的实际地址上。因此,当进程需要读取或写入某个特定的内存地址时,需要通过内核来实现地址映射和内存访问的具体操作。 首先,进程需要向内核发送系统调用来请求特定内存操作,例如请求分配内存空间、将某个文件映射到内存中、读取或写入特定内存地址等。内核收到请求后,会负责检查和管理系统中的物理内存资源,并根据进程的请求进行相应的操作。 对于读取操作,内核先检查请求的地址是否有效、是否有访问权限等,然后根据映射关系在物理内存中找到对应的数据,最后将数据通过内核返回给进程。 对于写入操作,内核也会进行类似的检查,然后根据映射关系找到对应的物理内存地址,将进程提供的数据写入到这个地址上。 此外,内核还负责处理页表、地址空间的切换、页面置换等管理工作,以确保进程的内存访问能够在物理内存上正确进行,保证系统的稳定性和安全性。 综上所述,进程访问内存通常需要内核介入,它负责管理和执行内存映射、地址转换、权限检查等相关操作,以保证进程能够正确、安全地访问内存。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值