c-使用带有ARM cpu的uart

  • 本文关键字:cpu uart ARM arm uart
  • 更新时间 :
  • 英文 :


我想为ARM编写一个裸机hello世界。该消息应该在uart上输出。设备树文件说明了uart:

            uart@09000 {
            compatible = "arm,pl011", "arm,primecell";
            reg = <0x9000 0x1000>;
            interrupts = <0x5>;
        };

这是我的"你好世界"节目。

// vexpress.js:651
const int    DR    = 0x00;
const int    FR    = 0x18;
const int    IBRD  = 0x24;
const int    FBRD  = 0x28;
const int    LCR_H = 0x2c;
const int    CR    = 0x30;
const int    IFLS  = 0x34;
const int    IMSC  = 0x38;
const int    MIS   = 0x40;
const int    ICR   = 0x44;
unsigned int *uart;
void
putc(char c)
{
    // wait for UART to become ready to transmit
    // vexpress.js:707
    while ((uart[FR] & (1 << 7)));
    uart[DR]= c;
    while ((uart[FR] & (1 << 7)));
}
void
puts(char *s) {    
    while(*s)
        putc(*(s++));    
}
int
main()
{
    char s[] = { 'H', 'a', 'l', 'l', 'o' , 0};
    int i;
    // vexpress.js:1455
    uart = (unsigned int*)0x10009000;

    // 1
    putc('H');
    putc('a');
    putc('l');
    putc('l');
    putc('o');
    putc(' ');
    putc('W');
    putc('e');
    putc('l');
    putc('t');
    putc('n');
    putc('r');
    // 2
    puts(s);
    // 3
    for(i=97;i<123;i++){
        putc((char)i);
    }
    // 4
    puts("Hello Worldnr");
    while(1);
}

因此,这个程序使用了几种方法将输出内容输出到uart。第1节(所有对putc的调用都起作用。但putc似乎不喜欢被循环调用。2、3和4都不起作用。第一个宪章起作用,奇怪的是,"\0"随后被发送,我不知道为什么。输出是

Hallo Welt                                                                      
a.........                                                               

我使用arm-js是因为这是唯一一个足够完整(mmu,可以运行linux(并且足够简单到单步(没有jit或类似(的arm模拟器。

此外,有没有一种方法可以集成一个在构建时读取设备树文件信息的uart驱动程序?有没有一个内核可以让我轻松地单独使用该部分?

/编辑

cpu是一个ARMv5 cortex-a9 vexpress处理器。我不确定还有哪些信息感兴趣,所以
这是设备树文件,这是汇编代码

uart = (unsigned int*)0x10009000;
while ((uart[FR] & (1 << 7)));

所以你取0x10009000,然后取一个初始化为0x18的变量FR,并将其用作偏移。uart被定义为一个int,所以取32位,因此取32位或4字节乘以0x18=0x60。所以你正在读取内存位置0x10009060,我怀疑这是否是你想要做的。无论如何,使用这样的指针不是一个好方法。(您也未能将uart声明为volatile(。DR将是唯一一个在0*4=0时工作的,并且您将获得地址0x10009000。

这些更新突出了一些问题,

const int FR = 6;
unsigned int volatile *uart;

最新更新