Laboratório 06
A documentação desta atividade de laboratório é complementar a documentação principal da disciplina.
Utilize como base a descrição apresentada no Moodle da disciplina.
| Tarefa | Template | Início | Fim | Conteúdo |
|---|---|---|---|---|
| LAB06 | TPL06 | 04-May-2026 | 11-May-2026 | Uso do STM32CubeMonitor; Visualização de variáveis; |
Conteúdo
Uso do STM32CubeMonitor; Visualização de variáveis;
- Verifique sua conta no my.st.com;
- Instale o STM32CubeMonitor;
- Instale o Node.js;
- Instale o STM32CubeProg;
Verifique o seu ambiente de desenvolvimento
- Git SCM
- GitHub CLI
- VS Code
Git is the most widely used source-code management tool among professional developers.
- Git is a free and open source distributed version control system designed to handle everything from small to very large projects with speed and efficiency.
winget install --id Git.Git -e --source winget
Configurações do git:
git config --list --show-origin
GitHub CLI brings GitHub to your terminal.
- GitHub CLI is a command line tool that allows you to interact with GitHub from the command line. It is available for Windows, macOS, and Linux.
winget install --id GitHub.cli -e --source winget
Status de login do GitHub CLI:
gh auth status
Visual Studio Code: IDE and Code Editor for Software Development.
- VS Code is a free source-code editor made by Microsoft for Windows, Linux and macOS. It includes support for debugging, embedded Git control, syntax highlighting, intelligent code completion, snippets, and code refactoring.
winget install --id Microsoft.VisualStudioCode -e --source winget
Extensões instaladas do Visual Studio Code para o perfil STM32:
code --list-extensions --profile "STM32"
Configure a ferramenta git
Configure o nome de usuário para todos os repositórios locais ligados às suas transações de commit:
git config --global user.name "Your Name"
Configure o email de usuário para todos os repositórios locais ligados às suas transações de commit:
git config --global user.email "you@example.com"
É recomendado verificar se a instalação do seu Git não está realizando nenhuma transformação entre LFs e CRLFs.
git config --global core.autocrlf false
Configure o git para usar o Visual Studio Code como editor padrão para tarefas como escrever mensagens de commit ou rebases interativos
git config --global core.editor "code --wait"
Habilite a coloração automática da saída da linha de comando do Git:
git config --global color.ui auto
Configura o Git para usar main como o nome do branch padrão sempre que você inicializar um novo repositório localmente:
git config --global init.defaultBranch main
Liste as configurações aplicadas:
git config --list --show-origin
- STM32CubeMX
- STM32CubeCLT
- ST-MCU-FINDER
- STM32CubeProg
- STM32CubeMonitor
STM32CubeMX is an initialization code generator.
- STM32CubeMX is a graphical tool that allows a very easy configuration of STM32 microcontrollers and microprocessors, as well as the generation of the corresponding initialization C code for the Arm® Cortex®-M core or a partial Linux® Device Tree for Arm® Cortex®-A core, through a step-by-step process.
STM32CubeCLT is an all-in-one multi-OS command-line toolset, which is part of the STM32Cube ecosystem.
- STM32CubeCLT includes GNU C/C++ for Arm® toolchain executables, GDB debugger, and STM32CubeProgrammer (STM32CubeProg) utility. It provides system view descriptors for the entire STM32 MCU portfolio and associate each STM32 MCU and development board with the appropriate SVD.
STM32 and STM8 product finder for desktops.
- ST-MCU-FINDER-PC allows exploring and connecting to the complete portfolio of STM32 Arm® Cortex®-M, STM32 Arm® Cortex®-A7, and STM8 microcontrollers, microprocessors, development boards and examples directly from the developer’s desktop environment.
STM32CubeProg is an all-in-one multi-OS software tool for programming STM32 products.
- STM32CubeProg provides an easy-to-use and efficient environment for reading, writing, and verifying device memory through both the debug interface (JTAG and SWD) and the bootloader interface (UART and USB DFU, I2C, SPI, and CAN). STM32CubeProgrammer is delivered in GUI (graphical user interface) and CLI (command-line interface) versions.
STM32CubeMonitor is a Monitoring tool to test STM32 applications at run-time.
- STM32CubeMonitor family of tools helps to fine-tune and diagnose STM32 applications at run-time by reading and visualizing their variables in real-time. With non-intrusive monitoring, STM32CubeMonitor preserves the real-time behavior of applications, and perfectly complements traditional debugging tools to perform application profiling.
Crie um novo repositório com base no template do LAB06
Escolha o Grupo e entre com o comando abaixo para criar o repositório no GitHub:
- A
- B
- C
- D
- E
- F
- G
- H
- I
- J
- K
- L
- X
- Grupo S22-A: https://github.com/ELT73A-S22-2026-1-A
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-A/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-A/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-B: https://github.com/ELT73A-S22-2026-1-B
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-B/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-B/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-C: https://github.com/ELT73A-S22-2026-1-C
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-C/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-C/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-D: https://github.com/ELT73A-S22-2026-1-D
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-D/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-D/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-E: https://github.com/ELT73A-S22-2026-1-E
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-E/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-E/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-F: https://github.com/ELT73A-S22-2026-1-F
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-F/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-F/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-G: https://github.com/ELT73A-S22-2026-1-G
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-G/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-G/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-H: https://github.com/ELT73A-S22-2026-1-H
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-H/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-H/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-I: https://github.com/ELT73A-S22-2026-1-I
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-I/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-I/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-J: https://github.com/ELT73A-S22-2026-1-J
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-J/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-J/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-K: https://github.com/ELT73A-S22-2026-1-K
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-K/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-K/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-L: https://github.com/ELT73A-S22-2026-1-L
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-L/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-L/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
- Grupo S22-X: https://github.com/ELT73A-S22-2026-1-X
- LAB Template: https://github.com/ELT73A-LAB-TPL/LAB06
Use o comando abaixo para criar o repositório no GitHub com base no template do laboratório LAB06:
gh repo create ELT73A-S22-2026-1-X/LAB06 --private -p ELT73A-LAB-TPL/LAB06 -c
Visualize o repositório:
gh repo view ELT73A-S22-2026-1-X/LAB06 --web
Abra o repositório clonado no VS Code:
code LAB06 --profile "STM32"
Instruções do LAB
Esta atividade de laboratório tem como objetivo utilizar o STM32CubeMonitor. Cada item equivale a 10% da nota.
- Crie um repositório (LAB06) via template (https://github.com/ELT73A-LAB-TPL/LAB06) na organização e clone;
- Importe e compile o código da pasta TIM2EXTI0ADC1PWM
- Verifique a configuração dos periféricos;
- Verifique o STM32CubeMonitor;
- Configure o executável e probes no STM32CubeMonitor;
- Deploy e Dashboard no STM32CubeMonitor;
- Adicione Write Panel para a variável BLUELED;
- Adicione Single value para o LED;
- Commit e push do Node-RED export flow;
- Envie o link do repositório no GitHub (hyperlink);
Avaliação
- Uso do template e código - 30%
- Configuração do STM32CubeMonitor - 20%
- Write Panel para a variável BLUELED - 10%
- Single value para o LED - 10%
- Commit e push do Node-RED export flow - 10%
- Link do repositório no GitHub (hyperlink) - 10%
Diagrama de pinos do STM32F4x1

User Code
Timer 2 com interrupção e saída PWM no canal 1
Inicialize o Timer 2 com suporte a rotina de interrupção e saída PWM no canal 1:
/* Initialize all configured peripherals */
MX_GPIO_Init();
MX_ADC1_Init();
MX_TIM2_Init();
/* USER CODE BEGIN 2 */
HAL_TIM_PWM_Start_IT(&htim2,TIM_CHANNEL_1);
/* USER CODE END 2 */
User Key
Toggle no LED interno via interrupção do User Key:
void EXTI0_IRQHandler(void)
{
/* USER CODE BEGIN EXTI0_IRQn 0 */
/* USER CODE END EXTI0_IRQn 0 */
HAL_GPIO_EXTI_IRQHandler(User_KEY_EXTI0_Pin);
/* USER CODE BEGIN EXTI0_IRQn 1 */
HAL_GPIO_TogglePin(GPIOC, GPIO_PIN_13);
/* USER CODE END EXTI0_IRQn 1 */
}
ADC1 na interrupção do Timer 2
Inicie o ADC1 na interrupção do Timer 2:
void TIM2_IRQHandler(void)
{
/* USER CODE BEGIN TIM2_IRQn 0 */
/* USER CODE END TIM2_IRQn 0 */
HAL_TIM_IRQHandler(&htim2);
/* USER CODE BEGIN TIM2_IRQn 1 */
HAL_ADC_Start_IT(&hadc1);
/* USER CODE END TIM2_IRQn 1 */
}
Leitura do AN1 e atualização do valor de comparação do PWM
Na interrupção do ADC1, faça a leitura do AN1 e atualize o valor de comparação do PWM:
TIM2->CCR1 = HAL_ADC_GetValue(&hadc1);
void ADC_IRQHandler(void)
{
/* USER CODE BEGIN ADC_IRQn 0 */
/* USER CODE END ADC_IRQn 0 */
HAL_ADC_IRQHandler(&hadc1);
/* USER CODE BEGIN ADC_IRQn 1 */
TIM2->CCR1 = HAL_ADC_GetValue(&hadc1);
/* USER CODE END ADC_IRQn 1 */
}
Tratamento do sinal de leitura do AN1
void ADC_IRQHandler(void)
{
/* USER CODE BEGIN ADC_IRQn 0 */
uint16_t adc1in1;
float voltage;
/* USER CODE END ADC_IRQn 0 */
HAL_ADC_IRQHandler(&hadc1);
/* USER CODE BEGIN ADC_IRQn 1 */
adc1in1 = HAL_ADC_GetValue(&hadc1);
voltage = (adc1in1*3.3)/4095;
/* USER CODE END ADC_IRQn 1 */
}
Como fazer commit da atualizações
Verifique o status do repositório
git status
Adicione os arquivos modificados
git add .
Realize o commit das alterações
git commit -m "My message for this commit!"
Envie para o repositório remoto (GitHub)
git push
Vizualize o log de alterações
git log