-
可以做,如果没记错,ST-Link就是这么做的。
-
关键是你做什么东西
-
有了吗??给个链接
-
的确, 我也发现.
这个串口调试助手的效率是不错的, 但是就这个校验有 BUG. 我发现是奇偶弄错了.
-
嗯,我的意思是,像我上面做法,破解的代码可以直接使用,破解者估计就不会再看HEX了,大量出货后,如果影响到自己的利益,然后拿它的设备,然后让MCU输出信息,不知道这种方法算不算证据,如果算的话,有能力就告他一把,没有能力,那就没有办法。。。
-
请说明这几行代码的出处?
-
麻烦呀。
-
谢谢5楼6楼4楼。等我解决了来散个分,现在还没搞定啊,实在是郁闷。
-
微软也没听说出芯片啊
-
网上看到类似的问题,说是在唤醒后未初始化NAND Flash,唤醒后需要初始化nand吗,所有寄存器的值不是都恢复了么?
-
回帖,看看我的积分
-
引用 2 楼 fpcc 的回复:
看看硬件有没有错误.然后再看软件.
硬件错误现在没办法找出来
软件是肯定没问题的,因为我是直接把镜像烧写到flash中,然后焊到板子上的。
-
没有!
需要自己做.
-
mzsId84kCbX6K
4HVF66kEbB41q
-
谢谢kyzf
那跟cpu有关系吗?
-
6410上 支持的PATA标准是ATA100,我在市场上买了个串口和并口的转接卡,在PC上可以用,不过在6410上就不正常,应该是支持的不好吧!
另外如果想扩展USB2.0接口能有什么方案呢?能不能从IDE接口转,或者是外扩控制器(用什么芯片,有没有驱动)?
-
哈哈,我看标题把STM三字替换成楼主合适
-
电容器一般会允许较大误差的,超过+100%/-50%的误差并不奇怪.
-
那是因为那个寄存器是"只写"的,你写给它的值无法从那个地址读取到.你读取的是另一个寄存器---很多时候是接收寄存器,当然也可能不是.
验证"只写"的寄存器是否成功的写了,只好从它的行为是否正确来判断.比如说,你写了发送寄存器,它就会把那个字节发送出去.
-
个人更倾向于使用PWM1,PWM2的方式,因为Toggle(翻转)模式需要考虑Channel的初始状态
需要在Toggle开始前强制设定两个Channel的相位,曾经产品上就出现过这样的问题(相同的HEX,运行时产生不同的结果)
根据版主的提示写的一段能满足楼主要求的代码
/**
软件: IAR 4.42 32K 限制版
库: 2.0
硬件: 万利 EKSTM3210B-LK1
说明: 使用TIM3的Channel3和Channel4产生楼主所述波形
*/
#define Fsys 72000000ul // system freq 72MHz
#define Fpwm 20000 // PWM freq 20K
#define PWM_DUTY 20 // PWM duty 20%
void ConfigTimer(void)
{
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
TIM_OCInitTypeDef TIM_OCInitStructure;
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB1PeriphClockCmd( RCC_APB1Periph_TIM3,ENABLE);
RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOB,ENABLE);
TIM_DeInit(TIM3);
TIM_TimeBaseStructure.TIM_Prescaler = 0;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_CenterAligned1;
TIM_TimeBaseStructure.TIM_Period = (Fsys/2) / Fpwm;
TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
TIM_TimeBaseStructure.TIM_RepetitionCounter = 0;
TIM_TimeBaseInit(TIM3,&TIM_TimeBaseStructure);
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
TIM_OCInitStructure.TIM_OutputNState = TIM_OutputState_Disable;
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
TIM_OCInitStructure.TIM_OCNPolarity = TIM_OCNPolarity_Low;
TIM_OCInitStructure.TIM_OCIdleState = TIM_OCIdleState_Reset;
TIM_OCInitStructure.TIM_OCNIdleState = TIM_OCIdleState_Reset;
TIM_OCInitStructure.TIM_Pulse = (((Fsys/2) / Fpwm) * PWM_DUTY) / 100;
TIM_OC3Init(TIM3,&TIM_OCInitStructure);
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM2;
TIM_OCInitStructure.TIM_Pulse = (((Fsys/2) / Fpwm) * (100-PWM_DUTY)) / 100;
TIM_OC4Init(TIM3,&TIM_OCInitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOB, &GPIO_InitStructure);
TIM_CtrlPWMOutputs(TIM3, ENABLE);
TIM_Cmd(TIM3,ENABLE);
}
无图无真相。图中CH3即 Timer3 Channel3(GPIOB.0), CH4即 Timer3 Channel4(GPIOB.1)
下载 (127.28 KB)
2009-12-28 17:49