当前位置:首页 > 单片机 > 单片机
[导读] 1、前言IO端口与IO内存的概念:外设中的寄存器称为是IO端口,外设中的内存称为是IO内存。二者统称为IO空间。Linux内核是通过虚拟地址访问外设的。所以需要先将虚拟地址映射到相应外设的物理地址上,lin

1、前言

IO端口与IO内存的概念:外设中的寄存器称为是IO端口,外设中的内存称为是IO内存。二者统称为IO空间。Linux内核是通过虚拟地址访问外设的。所以需要先将虚拟地址映射到相应外设的物理地址上,linux的映射方式有两种:静态映射(map_desc)和动态映射(ioremap),其实也是内核访问外设资源的方式。

2、静态映射基本过程:

在驱动中配置寄存器,可以调用类似于s3c_gpio_cfgpin、s3c_gpio_setpull、gpio_direction_output等直接配置IO寄存器的函数。这些函数访问的虚拟地址,这些虚拟地址都是已经在启动启动的时候通过静态映射方式映射到IO寄存器的物理地址上。

静态映射概念:所谓的静态映射是指,虚拟地址到物理地址的转换所需要的页表在操作系统启动时已经配置好,不需要用户进行配置,虚拟地址到物理地址的查表转换可直接完成(fromnet)。

以s5pv210为例讲述:

MACHINE_START(SMDKV210,"SMDKV210")

/* Maintainer: Kukjin Kim */

.boot_params =S5P_PA_SDRAM + 0x100,

.init_irq =s5pv210_init_irq,

.map_io = smdkv210_map_io,

.init_machine = smdkv210_machine_init,

#ifdefCONFIG_S5P_HIGH_RES_TIMERS

.timer = &s5p_systimer,

#else

.timer =&s5p_timer,

#endif

MACHINE_END

其中IO映射函数是smdkv210_map_io实现:

staticvoid __init smdkv210_map_io(void)

{

s5p_init_io(NULL,0, S5P_VA_CHIPID);

s3c24xx_init_clocks(24000000);

s5pv210_gpiolib_init();

s3c24xx_init_uarts(smdkv210_uartcfgs,

ARRAY_SIZE(smdkv210_uartcfgs));

#ifndefCONFIG_S5P_HIGH_RES_TIMERS

s5p_set_timer_source(S5P_PWM2, S5P_PWM4);

#endif

s5p_reserve_bootmem(s5pv210_media_devs,

ARRAY_SIZE(s5pv210_media_devs),

S5P_RANGE_MFC);

}

该函数中调用s5p_init_io进行地址的映射,

/*read cpu identification code */

void__inits5p_init_io(struct map_desc*mach_desc,

int size, void __iomem *cpuid_addr)

{

unsigned long idcode;

/* initialize the io descriptors we need forinitialization */

iotable_init(s5p_iodesc, ARRAY_SIZE(s5p_iodesc));

if (mach_desc)

iotable_init(mach_desc, size);

idcode = __raw_readl(cpuid_addr);

s3c_init_cpu(idcode,cpu_ids, ARRAY_SIZE(cpu_ids));

}

其中最重要是struct map_desc s5p_iodesc[]结构体 和 staticstruct map_desc s5pv210_iodesc[]:

structmap_desc{

unsigned long virtual; // IO空间映射后的虚拟地址

unsigned long pfn; // IO空间的物理地址所在的页帧号

unsigned long length; // IO空间的长度

unsigned int type; // IO空间的类型

};

/*minimal IO mapping这部分是最小系统层次的映射*/

staticstruct map_desc s5p_iodesc[] __initdata = {

{

.virtual =(unsigned long)S5P_VA_CHIPID,

.pfn =__phys_to_pfn(S5P_PA_CHIPID),

.length =SZ_4K,

.type =MT_DEVICE,

}, {

.virtual = (unsigned long)S3C_VA_SYS,

.pfn = __phys_to_pfn(S5P_PA_SYSCON),

.length = SZ_64K,

.type = MT_DEVICE,

},{

.virtual =(unsigned long)S3C_VA_TIMER,

.pfn =__phys_to_pfn(S5P_PA_TIMER),

.length =SZ_16K,

.type =MT_DEVICE,

},{

.virtual =(unsigned long)S3C_VA_WATCHDOG,

.pfn =__phys_to_pfn(S3C_PA_WDT),

.length =SZ_4K,

.type =MT_DEVICE,

}, {

.virtual =(unsigned long)S5P_VA_SROMC,

.pfn =__phys_to_pfn(S5P_PA_SROMC),

.length =SZ_4K,

.type =MT_DEVICE,

},

};

/*Initial IO mappings*/

staticstruct map_desc s5pv210_iodesc[] __initdata = {

{

.virtual =(unsigned long)S5P_VA_SYSTIMER,

.pfn =__phys_to_pfn(S5PV210_PA_SYSTIMER),

.length =SZ_4K,

.type =MT_DEVICE,

}, {

.virtual =(unsigned long)S5P_VA_GPIO,

.pfn =__phys_to_pfn(S5PV210_PA_GPIO),

.length =SZ_4K,

.type =MT_DEVICE,

}, {

.virtual =(unsigned long)VA_VIC0,

.pfn =__phys_to_pfn(S5PV210_PA_VIC0),

.length =SZ_16K,

.type =MT_DEVICE,

}, {

.virtual =(unsigned long)VA_VIC1,

.pfn =__phys_to_pfn(S5PV210_PA_VIC1),

.length =SZ_16K,

.type =MT_DEVICE,

}, {

.virtual =(unsigned long)VA_VIC2,

.pfn =__phys_to_pfn(S5PV210_PA_VIC2),

.length =SZ_16K,

.type =MT_DEVICE,

}, {

.virtual =(unsigned long)VA_VIC3,

.pfn =__phys_to_pfn(S5PV210_PA_VIC3),

.length =SZ_16K,

.type =MT_DEVICE,

}, {

.virtual =(unsigned long)S3C_VA_UART,

.pfn =__phys_to_pfn(S3C_PA_UART),

.length =SZ_512K,

.type =MT_DEVICE,

}, {

.virtual =(unsigned long)S5P_VA_DMC0,

.pfn =__phys_to_pfn(S5PV210_PA_DMC0),

.length =SZ_4K,

.type =MT_DEVICE,

}, {

.virtual =(unsigned long)S5P_VA_DMC1,

.pfn =__phys_to_pfn(S5PV210_PA_DMC1),

.length =SZ_4K,

.type =MT_DEVICE,

},{

.virtual = (unsigned long)S5P_VA_BUS_AXI_DSYS,

.pfn = __phys_to_pfn(S5PV210_PA_BUS_AXI_DSYS),

.length= SZ_4K,

.type = MT_DEVICE,

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭