head.s分析(5):关闭串口

系统 1362 0

快乐虾

http://blog.csdn.net/lights_joy/

lights@hb165.com

本文适用于

ADI bf561 DSP

uclinux-2008r1.5-rc3 ( 移植到 vdsp5)

Visual DSP++ 5.0(update 5)

欢迎转载,但请保留作者信息

/* Initialise UART - when booting from u-boot, the UART is not disabled

* so if we dont initalize here, our serial console gets hosed */

p0.h = hi(UART_LCR);

p0.l = lo(UART_LCR);

r0 = 0x0(Z);

w[p0] = r0.L; /* To enable DLL writes */

ssync;

p0.h = hi(UART_DLL);

p0.l = lo(UART_DLL);

r0 = 0x0(Z);

w[p0] = r0.L;

ssync;

p0.h = hi(UART_DLH);

p0.l = lo(UART_DLH);

r0 = 0x00(Z);

w[p0] = r0.L;

ssync;

p0.h = hi(UART_GCTL);

p0.l = lo(UART_GCTL);

r0 = 0x0(Z);

w[p0] = r0.L; /* To enable UART clock */

ssync;

这段代码用于关闭串串口,但是这里有个问题,在设置 UART_DLL UART_DLH 时必须将 UART_LCR 的最高位设置为 1 ,但是原始代码中却未设置,这样就造成了设置 UART_DLL UART_DLH 必然失败。所以

r0 = 0x0(Z);

应该改为

r0 = 0x80(Z);

下面的说明来自于 vdsp 文档:

The UART _ DLL register is mapped to the same address as the UART_THR and UART_RBR registers. The UART_DLH register is mapped to the same address as the Interrupt Enable register ( UART_IER ). The DLAB bit in UART_LCR must be set before the UART Divisor Latch registers can be accessed.

UART_LCR

在将 UART_DLH UART_DLL 0 后,它的 Divisor 将变成 65536

这一句

w[p0] = r0.L; /* To enable UART clock */

也相当奇怪,如果按照注释的说法是要启用 UART clock ,但是将 UART_GCTL 的值设置为 0 却明显是关闭 clock

UART_GCTL

1 参考资料

head.s 分析 (1) :保存 u-boot 传递过来的指针 (2009-1-19)

head.s 分析 (2) SYSCFG 配置 (2009-1-19)

head.s 分析 (3) :数据及指针寄存器清 0 (2009-1-19)

head.s 分析 (4) :关闭 CACHE (2009-01-19)

head.s分析(5):关闭串口


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论