4213|7

63

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

wince debug口 修改问题,成功一半了~整个系统变得很慢! [复制链接]

cpu是2440的,跑ce4.2;
uart0被wince用作debug口,同时在ce里也能打开com1,只是波特率在denug.c写死在115200了,平时用的时候可以正常输出debug信息同时也可以用来数据传输。

为了不让次端口输出调试信息,我在debug.c修改如下

#include
#include
#include

#define     UART0BaudRate        115200
#define     UART1BaudRate        115200 //38400

void OEMInitDebugSerial(void)
{
}
void
OEMWriteDebugLED(WORD wIndex, DWORD dwPattern)
{
}
void
OEMWriteDebugString(unsigned short *str)
{       
}

void
OEMWriteDebugByte(UCHAR ch)
{
}


int
OEMReadDebugByte()
{   
return 0;
}

void
OEMClearDebugCommError(void)
{}



其实就是吧所有debug相关的函数的函数体都删除。
编译下载后,串口不输出调试信息了,在9600/115200/19200波特率下收发正常,只是发快了会有些丢包,驱动需要改进。


串口进本功能实现了,但是发现修改后系统变得很慢:
开机后,桌面图标只显示一两个,只要一插usb设备,就都显示了。
打开“我的电脑”非常慢,总而言之,整个系统变得很慢。


最新回复

我也遇到了,我是uart0-com1               uart2-com2 uart1是debug口,和你一样的需求,我uart1的驱动加上之后,和你问题一样,那个慢不是一般的慢! 不过偶尔正常的时候,串口收发还是可以的! 后来,我发现我为了修改方便我把:uart0-com1                             uart1-com2                             uart2-com3 才有的这个问题。 最后调整一下,uart1-com3,就ok了! 估计系统里面有其他调用! 还有一个USE_AFC 0 屏蔽了SL_Init里面的 //S2440_SetIrDAIOP(pHead); 新增了S2440_SetIOP(pHead); ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; UART1 for com2 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; [HKEY_LOCAL_MACHINE\Drivers\BuiltIn\UART1]         "DeviceArrayIndex"=dword:2         "Irq"=dword:13         "IoBase"=dword:50004000         "IoLen"=dword:2C         "Prefix"="COM"         "Dll"="SER2440.Dll"         "Order"=dword:0         "Index"=dword:3         "Priority"=dword:0         "Port"="COM3:"         "DeviceType"=dword:0         "FriendlyName"="Serial Port COM3"         "Tsp"="Unimodem.dll"         "DevConfig"=hex: 10,00, 00,00, 05,00,00,00, 10,01,00,00, 00,4B,00,00, 00,00, 08, 00, 00, 00,00,00,00   详情 回复 发表于 2008-9-26 12:31
点赞 关注

回复
举报

86

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
自己顶一下~
发现不停的电屏幕,会稍微快一点~
是不是和lcd驱动有关西那?
 
 

回复

72

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
没有人知道?
 
 
 

回复

77

帖子

0

TA的资源

一粒金砂(初级)

4
 
串口进本功能实现了,但是发现修改后系统变得很慢:
开机后,桌面图标只显示一两个,只要一插usb设备,就都显示了。
打开“我的电脑”非常慢,总而言之,整个系统变得很慢。


逐个排除, 先去掉串口驱动看看系统是否慢?
也许是串口什么地方执行了等待之类事情。。。。
看看注册表那个USB是否有和串口关联的地方??
 
 
 

回复

55

帖子

0

TA的资源

一粒金砂(初级)

5
 
换一个口做调试口,如果只是把函数里面的代码去对掉,每次打印信息的时候还会跑这些函数,可能这些函数调用会产生一些错误或异常就会引起系统不稳定.
 
 
 

回复

67

帖子

0

TA的资源

一粒金砂(初级)

6
 
禁止调试信息的输出是很常见的需求,但不是这么个做法,太极端了。

系统变慢是因为取消了这些函数?先确认是不是这个原因,别开始就找错方向。恢复这些函数看一下。
 
 
 

回复

84

帖子

0

TA的资源

一粒金砂(初级)

7
 
我知道,但是我不告诉你
 
 
 

回复

68

帖子

0

TA的资源

一粒金砂(初级)

8
 
我也遇到了,我是uart0-com1
              uart2-com2
uart1是debug口,和你一样的需求,我uart1的驱动加上之后,和你问题一样,那个慢不是一般的慢!
不过偶尔正常的时候,串口收发还是可以的!

后来,我发现我为了修改方便我把:uart0-com1
                            uart1-com2
                            uart2-com3 才有的这个问题。
最后调整一下,uart1-com3,就ok了!
估计系统里面有其他调用!
还有一个USE_AFC 0
屏蔽了SL_Init里面的
//S2440_SetIrDAIOP(pHead);
新增了S2440_SetIOP(pHead);

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; UART1 for com2
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
[HKEY_LOCAL_MACHINE\Drivers\BuiltIn\UART1]
        "DeviceArrayIndex"=dword:2
        "Irq"=dword:13
        "IoBase"=dword:50004000
        "IoLen"=dword:2C
        "Prefix"="COM"
        "Dll"="SER2440.Dll"
        "Order"=dword:0
        "Index"=dword:3
        "Priority"=dword:0
        "Port"="COM3:"
        "DeviceType"=dword:0
        "FriendlyName"="Serial Port COM3"
        "Tsp"="Unimodem.dll"
        "DevConfig"=hex: 10,00, 00,00, 05,00,00,00, 10,01,00,00, 00,4B,00,00, 00,00, 08, 00, 00, 00,00,00,00
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/8 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表