专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
请问有谁用STM32驱动过时钟芯片DS12887吗?
2019-07-14 15:20
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
6148
13
1225
在用
STM32
F1 驱动时钟
芯片
,我直接移植了网上52的例程,但是时钟芯片一直没有工作。
论坛
里有人用过这个芯片吗?求教。
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
13条回答
uwufwjrw
2019-07-15 23:21
本帖最后由 格式化/tp 于 2017-9-27 11:33 编辑
#include <stdio.h>
#include <stm32f10x.h>
#include <string.h>
// 延时n毫秒
void delay(uint16_t nms)
{
TIM6->ARR = 10 * nms - 1;
TIM6->PSC = 7199;
TIM6->EGR = TIM_EGR_UG;
TIM6->CR1 = TIM_CR1_OPM | TIM_CR1_CEN;
while (TIM6->CR1 & TIM_CR1_CEN);
}
int fputc(int ch, FILE *fp)
{
if (fp == stdout)
{
if (ch == ' ')
{
while ((USART1->SR & USART_SR_TXE) == 0);
USART1->DR = ' ';
}
while ((USART1->SR & USART_SR_TXE) == 0);
USART1->DR = ch;
}
return ch;
}
int main(void)
{
char buf[20];
RCC->AHBENR |= RCC_AHBENR_FSMCEN;
RCC->APB1ENR = RCC_APB1ENR_TIM6EN;
RCC->APB2ENR = RCC_APB2ENR_IOPAEN | RCC_APB2ENR_IOPBEN | RCC_APB2ENR_IOPDEN | RCC_APB2ENR_IOPEEN | RCC_APB2ENR_USART1EN;
GPIOA->CRH = 0x444444b3; // PA8为RST复位引脚(默认输出低电平), PA9为串口1发送引脚
GPIOB->CRL = 0xb4444444; // PB7为NADV, 取反后送到AS引脚上, 该引脚不可用地址线代替!
GPIOD->CRL = 0xb4bb44bb; // PD0~1为AD2~3, PD4为NOE接DS引脚, PD5为NWE接RW引脚, PD7为NE1片选引脚接CS
GPIOD->CRH = 0xbb444444; // PD14~15为AD0~1
GPIOE->CRL = 0xb4444444; // PE7为AD4
GPIOE->CRH = 0x44444bbb; // PE8~10为AD5~7
USART1->BRR = 625; // 串口波特率为115200
USART1->CR1 = USART_CR1_UE | USART_CR1_TE; // 串口1只允许发送
// FSMC的Bank1, Subbank1设为8位NOR Flash地址/数据线复用模式, 关闭NWAIT引脚
FSMC_Bank1->BTCR[0] &= ~(FSMC_BCR1_WAITEN | FSMC_BCR1_MWID);
// 下面为可选配置, 用于加快访存速度
// HCLK=72MHz时, DATAST的最小值为2, 即3xHCLK clock cycles
FSMC_Bank1->BTCR[1] = (FSMC_Bank1->BTCR[1] & ~(FSMC_BTR1_BUSTURN | FSMC_BTR1_DATAST | FSMC_BTR1_ADDHLD | FSMC_BTR1_ADDSET)) | FSMC_BTR1_DATAST_1 | FSMC_BTR1_ADDHLD_0;
printf("STM32F103VE FSMC DS12C887 ");
delay(200);
GPIOA->BSRR = GPIO_BSRR_BS8; // RESET=1, 撤销复位信号
// 读写自由SRAM区域
strcpy((char *)0x60000033, "This is a string!");
memcpy(buf, (char *)0x60000033, sizeof(buf));
printf("str=%s ", buf);
// 读A~D寄存器
printf("A=0x%02x B=0x%02x C=0x%02x D=0x%02x ", *(__IO uint8_t *)0x6000000a, *(__IO uint8_t *)0x6000000b, *(__IO uint8_t *)0x6000000c, *(__IO uint8_t *)0x6000000d);
while (1)
__WFI();
}
void HardFault_Handler(void)
{
printf("Hard Error! ");
while (1);
}
加载中...
查看其它13个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
#include <stdio.h>
#include <stm32f10x.h>
#include <string.h>
// 延时n毫秒
void delay(uint16_t nms)
{
TIM6->ARR = 10 * nms - 1;
TIM6->PSC = 7199;
TIM6->EGR = TIM_EGR_UG;
TIM6->CR1 = TIM_CR1_OPM | TIM_CR1_CEN;
while (TIM6->CR1 & TIM_CR1_CEN);
}
int fputc(int ch, FILE *fp)
{
if (fp == stdout)
{
if (ch == ' ')
{
while ((USART1->SR & USART_SR_TXE) == 0);
USART1->DR = ' ';
}
while ((USART1->SR & USART_SR_TXE) == 0);
USART1->DR = ch;
}
return ch;
}
int main(void)
{
char buf[20];
RCC->AHBENR |= RCC_AHBENR_FSMCEN;
RCC->APB1ENR = RCC_APB1ENR_TIM6EN;
RCC->APB2ENR = RCC_APB2ENR_IOPAEN | RCC_APB2ENR_IOPBEN | RCC_APB2ENR_IOPDEN | RCC_APB2ENR_IOPEEN | RCC_APB2ENR_USART1EN;
GPIOA->CRH = 0x444444b3; // PA8为RST复位引脚(默认输出低电平), PA9为串口1发送引脚
GPIOB->CRL = 0xb4444444; // PB7为NADV, 取反后送到AS引脚上, 该引脚不可用地址线代替!
GPIOD->CRL = 0xb4bb44bb; // PD0~1为AD2~3, PD4为NOE接DS引脚, PD5为NWE接RW引脚, PD7为NE1片选引脚接CS
GPIOD->CRH = 0xbb444444; // PD14~15为AD0~1
GPIOE->CRL = 0xb4444444; // PE7为AD4
GPIOE->CRH = 0x44444bbb; // PE8~10为AD5~7
USART1->BRR = 625; // 串口波特率为115200
USART1->CR1 = USART_CR1_UE | USART_CR1_TE; // 串口1只允许发送
// FSMC的Bank1, Subbank1设为8位NOR Flash地址/数据线复用模式, 关闭NWAIT引脚
FSMC_Bank1->BTCR[0] &= ~(FSMC_BCR1_WAITEN | FSMC_BCR1_MWID);
// 下面为可选配置, 用于加快访存速度
// HCLK=72MHz时, DATAST的最小值为2, 即3xHCLK clock cycles
FSMC_Bank1->BTCR[1] = (FSMC_Bank1->BTCR[1] & ~(FSMC_BTR1_BUSTURN | FSMC_BTR1_DATAST | FSMC_BTR1_ADDHLD | FSMC_BTR1_ADDSET)) | FSMC_BTR1_DATAST_1 | FSMC_BTR1_ADDHLD_0;
printf("STM32F103VE FSMC DS12C887 ");
delay(200);
GPIOA->BSRR = GPIO_BSRR_BS8; // RESET=1, 撤销复位信号
// 读写自由SRAM区域
strcpy((char *)0x60000033, "This is a string!");
memcpy(buf, (char *)0x60000033, sizeof(buf));
printf("str=%s ", buf);
// 读A~D寄存器
printf("A=0x%02x B=0x%02x C=0x%02x D=0x%02x ", *(__IO uint8_t *)0x6000000a, *(__IO uint8_t *)0x6000000b, *(__IO uint8_t *)0x6000000c, *(__IO uint8_t *)0x6000000d);
while (1)
__WFI();
}
void HardFault_Handler(void)
{
printf("Hard Error! ");
while (1);
}
一周热门 更多>