- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我是 STM32 的新手,而不是嵌入式开发(具有 PIC、dsPIC、MSP430 的经验)。
我正在尝试使用直接寄存器操作编写一个基本库(STMCube HAL 很酷,但我发现无论如何我都必须阅读数据表,因此首选寄存器操作)。本质上,我只是想使 Blue Pill
开发板上的 LED 闪烁,该开发板上的引脚为 C13
。
我可以编译、刷新和调试,但是当我调试时,LED 不闪烁并且寄存器没有变化。寄存器值本身实际上并没有那么重要,因此您不需要出去查看数据表。我只需要能够操纵它们!
单步执行调试器工作正常,variables
观察窗口也适当更新。
虽然这并不详尽(已经几个小时了,所以我可能忘记包括一些),但这些是我尝试过的一些事情:
BOOTx
引脚配置所有的结果都是一样的。我怀疑我可能在 CMSIS 中遗漏了一些东西或一个必要的包含文件,我似乎找不到它。
我可能遗漏的另一点涉及振荡器设置。据我了解,启动时有一个默认配置,除非我想更改它,否则我不必担心。也许这是有缺陷的?
当我尝试使用 STM32CUBEMX HAL 进行基本切换时,它起作用了。这让我觉得我在包含、项目设置、振荡器设置等方面缺少一些基本的东西?
#include "gpio.h"
#define LED_PIN 13
int main(void)
{
uint32_t i;
// initialize the peripherals
GPIO_init();
GPIOC_setupOutput(LED_PIN, PUSH_PULL, PIN_SPEED_50MHz);
while(1)
{
GPIOC_setPin(LED_PIN);
for(i=0; i<4000000; i++);
GPIOC_clearPin(LED_PIN);
for(i=0; i<4000000; i++);
}
}
#ifndef _GPIO_H
#define _GPIO_H
#include <stdint.h>
#include <stdbool.h>
typedef enum{
ANALOG=0b00, FLOATING=0b01, PULL_UP_PULL_DOWN=0b10
}InputPinMode;
typedef enum{
PUSH_PULL=0b00, OPEN_DRAIN=0b01, AF_PUSH_PULL=0b10, AF_OPEN_DRAIN=0b11
}OutputPinMode;
typedef enum{
PIN_SPEED_2MHz=0b10, PIN_SPEED_10MHz=0b01, PIN_SPEED_50MHz=0b11
}PinSpeed;
void GPIO_init(void);
void GPIOA_setupInput(uint8_t pinNumber, InputPinMode mode);
void GPIOC_setupInput(uint8_t pinNumber, InputPinMode mode);
void GPIOA_setupOutput(uint8_t pinNumber, OutputPinMode mode, PinSpeed speed);
void GPIOC_setupOutput(uint8_t pinNumber, OutputPinMode mode, PinSpeed speed);
bool GPIOA_readPin(uint8_t pinNumber);
void GPIOA_setPin(uint8_t pinNumber);
void GPIOC_setPin(uint8_t pinNumber);
void GPIOA_clearPin(uint8_t pinNumber);
void GPIOC_clearPin(uint8_t pinNumber);
#endif
#include "stm32f1xx.h"
#include "gpio.h"
/**
* @brief Initialize GPIO
*/
void GPIO_init(void){
RCC->APB2ENR |= RCC_APB2ENR_IOPAEN;
RCC->APB2ENR |= RCC_APB2ENR_IOPBEN;
RCC->APB2ENR |= RCC_APB2ENR_IOPCEN;
RCC->APB2ENR |= RCC_APB2ENR_IOPDEN;
RCC->APB2ENR |= RCC_APB2ENR_IOPEEN;
}
/**
* @brief Setup pin as an input
* @param pinNumber the pin number
* @param mode the input mode
*/
void GPIOA_setupInput(uint8_t pinNumber, InputPinMode mode){
uint32_t pinNumberLocation, regValue;
if(pinNumber < 8){
pinNumberLocation = pinNumber << 2; // bit location
regValue = (mode << 2) << pinNumberLocation;
GPIOA->CRL &= ~(0b1111 << pinNumberLocation); // clear the register
GPIOA->CRL = regValue;
}else{
pinNumberLocation = (pinNumber - 8) << 2; // bit location
regValue = (mode << 2) << pinNumberLocation;
GPIOA->CRH &= ~(0b1111 << pinNumberLocation); // clear the register
GPIOA->CRH = regValue;
}
}
/**
* @brief Setup port A pin as an output
* @brief pinNumber the pin number
* @brief mode the output mode
* @brief speed the pin speed (lower results in less noise)
*/
void GPIOA_setupOutput(uint8_t pinNumber, OutputPinMode mode, PinSpeed speed){
uint32_t pinNumberLocation, regValue;
if(pinNumber < 8){
pinNumberLocation = pinNumber << 2; // bit location
regValue = ((mode << 2) << pinNumberLocation) + speed;
GPIOA->CRL &= ~(0b1111 << pinNumberLocation); // clear the register
GPIOA->CRL |= regValue;
}else{
pinNumberLocation = (pinNumber - 8) << 2; // bit location
regValue = ((mode << 2) << pinNumberLocation) + speed;
GPIOA->CRH &= ~(0b1111 << pinNumberLocation); // clear the register
GPIOA->CRH |= regValue;
}
}
/**
* @brief Setup port C pin as an output
* @brief pinNumber the pin number
* @brief mode the output mode
* @brief speed the pin speed (lower results in less noise)
*/
void GPIOC_setupOutput(uint8_t pinNumber, OutputPinMode mode, PinSpeed speed){
uint32_t pinNumberLocation, regValue;
if(pinNumber < 8){
pinNumberLocation = pinNumber << 2; // bit location
regValue = ((mode << 2) << pinNumberLocation) + speed;
GPIOC->CRL &= ~(0b1111 << pinNumberLocation); // clear the register
GPIOC->CRL |= regValue;
}else{
pinNumberLocation = (pinNumber - 8) << 2; // bit location
regValue = ((mode << 2) << pinNumberLocation) + speed;
GPIOC->CRH &= ~(0b1111 << pinNumberLocation); // clear the register
GPIOC->CRH |= regValue;
}
}
bool GPIOA_readPin(uint8_t pinNumber){
uint16_t mask = 1 << pinNumber;
if(GPIOA->IDR & mask)
return true;
else
return false;
}
void GPIOA_setPin(uint8_t pinNumber){ GPIOA->BSRR = (1 << pinNumber);}
void GPIOC_setPin(uint8_t pinNumber){ GPIOC->BSRR = (1 << pinNumber);}
void GPIOA_clearPin(uint8_t pinNumber){ GPIOA->BSRR = ~(1 << (pinNumber + 16));}
void GPIOC_clearPin(uint8_t pinNumber){ GPIOC->BSRR = ~(1 << (pinNumber + 16));}
最佳答案
PB2 上的二极管 - 工作代码
volatile uint32_t delay;
#include "stm32f10x.h"
int main(void)
{
RCC->APB2ENR = RCC_APB2ENR_IOPBEN;
GPIOB->CRL |= GPIO_CRL_MODE2_1;
GPIOB->CRL &= ~GPIO_CRL_CNF2_0;
while(1)
{
GPIOB->ODR |= GPIO_ODR_ODR2; //or GPIO_ODR_2 depending of the .h header version
for(delay = 2000000; delay; delay--);
GPIOB->ODR &= ~GPIO_ODR_ODR2; //or GPIO_ODR_2 depending of the .h header version
for(delay = 2000000; delay; delay--);
GPIOB->BSRR = 1 << 2;
for(delay = 2000000; delay; delay--);
GPIOB->BSRR = 1 << (2 + 16);
for(delay = 2000000; delay; delay--);
}
} // change
关于c - STM32F103C8/CoIDE/ST-LinkV2 无法更新寄存器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44973472/
我无法理解如何使用一些旧的 VGA 代码在这个示例中设置序列 Controller 寄存器: mov dx,SC_INDEX mov ax,0604h out dx,ax
我希望对 zmm 0-31 寄存器集的四字元素执行整数算术运算并保留这些运算产生的进位位。看来这只有在通用寄存器集中处理数据时才有可能。 因此,我想将信息从 zmm 0-31 寄存器之一复制到通用寄存
ARM 64中包含多种寄存器,下面介绍一些常见的寄存器。 1 通用寄存器 ARM 64包含31个64bit寄存器,记为X0~X30。 每一个通用寄存器,它的低32bit都可以被访问,记为W0~W
1.寄存器 组合逻辑存在一个最大的缺点就是存在竞争与冒险,系统会产生不定态;使用时序逻辑电路就会极大的改善这种情况 寄存器具有存储功能,一般是由D触发器构成,由时钟脉冲控制,每个D触发器能够
使用 $gp 是否存在危险?注册以存储值?我想我的问题是 $gp 的真正功能是什么?它是否以某种方式在幕后调用,以便如果我使用它,事情可能会变得非常非常错误? 最佳答案 那么,$gp register
我遇到了这段代码的问题,我无法弄清楚问题出在哪里。所以当我运行这段代码时:if $row["count"] > 0 else块运行和 $_SESSION["error"]设置。 当$row["coun
所以我正在做二进制炸弹的变体。这就是阶段 0x0000000000401205 : sub $0x8,%rsp 0x0000000000401209 : cmp $0x3,
我在一个名为 (EmployeeDetailKey - varchar(10)) 的字段中获得了一个值,其中包含顺序值,例如 00001, 00002, 00003.... 它位于 Employeed
我有一个要求,应该为每个调用的线程分配一个计数器变量。但我没有得到预期的结果,实际上计数器在线程中重复。我创建了一个虚拟表和一个过程来将计数器值插入到表中。无论如何,是否可以更改代码以便线程获得递增的
预期输出:需要打印第4季度的wage_amt +--------------+--------------+--------------+--------------+ | wages_amt_q1
如何匹配模式 abc_[someArbitaryStringHere]_xyz? 为了澄清,我希望正则表达式能够匹配以下性质的字符串: abc_xyz、abc_asdfsdf_xyz、abc_32rw
从下拉列表(自定义)中选择一个值而不是常规下拉列表,它有很多下拉值 我可以用代码选择第一个值 find('.selected', :text=>arg1,exact: false).click 但无法
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我有 .csv 文件中的数据,它包含 2 列 x 轴和 y 轴。从 .csv 文件读取轴,然后使用拉伸(stretch)指数函数拟合数据,但显示错误。 这里我给出示例数据以方便理解。 我的函数是f(x
我正在尝试使用以下汇编代码将磁盘扇区加载到内存中,但正如我在终端中使用一些 int 0x10 时发现的那样,它不起作用的原因是它陷入了无限循环。我以为循环会自动为我递减 cx 寄存器。下面是代码,其中
我正在尝试编写一个脚本,该脚本将在 vim 中打开一个文件并将其中的特定行复制到 vim 的寄存器之一中。当脚本再次运行时,它会决定再次打开文件,然后将 vim 寄存器中的值粘贴回。实际上,脚本应该在
我目前正在尝试弄清楚如何将指针寄存器 SI 指向的内存中的第一个字节添加到 AX 寄存器的当前内容中。 因此,如果 SI 包含某个地址,并且该地址在内存中的值是:00 和 01,我希望将 00 添加到
我试图将两个 16 位数字与以下 NASM 代码相乘: mov ax, [input1] mov bx, [input2] mul bx 前面代码的结果存储在 DX:AX 我试图使用来自单独库“pri
我正在尝试修改 rip 寄存器(只是为了好玩)。 buffer 应该是内存地址,所以不知道为什么会得到Error: operand type mismatch for 'movq' #include
我可以告诉gcc-style inline assembly把我的__m512i变量到特定 zmm注册,如 zmm31 ? 最佳答案 就像在根本没有特定寄存器约束的目标(如 ARM)上一样,使用 lo
我是一名优秀的程序员,十分优秀!