cancel
Showing results for 
Search instead for 
Did you mean: 

Enable SWO on CubeIDE 1.12.1 - Board used Nucleo-H755ZI

MD
Associate II

Hello,

I went through all the SWO related topics, and it was a bit confusing for me to get it running, so I summarized the steps to have it working on a Nucleo H755.

In my project I have the main clock set at 400MHz, Timer2 running at 1Hz and Debug set as "Trace Asyncronous Sw"

In my main.c I have added just this:

 

 

 

  /* USER CODE BEGIN 2 */
#define SWO_BASE (0x5C003000UL)
#define SWTF_BASE (0x5C004000UL)

 uint32_t SWOSpeed = 2000000; // [Hz] we have 2 Mbps SWO speed in ST-Link SWV viewer
 uint32_t SWOPrescaler = (SystemCoreClock / SWOSpeed) - 1; /* divider value */

 //enable debug clocks
 DBGMCU->CR = 0x00700000; //enable debug clocks

 //UNLOCK FUNNEL
 //SWTF->LAR unlock
 *((__IO uint32_t *)(SWTF_BASE + 0xFB0)) = 0xC5ACCE55; //unlock SWTF

 //SWO->LAR unlock
 *((uint32_t *)(SWO_BASE + 0xFB0)) = 0xC5ACCE55; //unlock SWO

 //SWO divider setting
 //This divider value (0x000000C7) corresponds to 400Mhz core clock
 //SWO->CODR = PRESCALER[12:0]
 *((__IO uint32_t *)(SWO_BASE + 0x010)) = SWOPrescaler; //clock divider

 //SWO set the protocol
 //SWO->SPPR = PPROT[1:0] = NRZ
 *((__IO uint32_t *)(SWO_BASE + 0x0F0)) = 0x00000002; //set to NRZ

 //Enable ITM input of SWO trace funnel, slave 0
 //SWTF->CTRL bit 0 ENSO = Enable
 *((__IO uint32_t *)(SWTF_BASE + 0x000)) |= 0x00000001; //enable

 LL_TIM_EnableCounter(TIM2);  //Used for LED toggle

  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
	  if (LL_TIM_IsActiveFlag_UPDATE(TIM2)) {
		  LL_TIM_ClearFlag_UPDATE(TIM2);
		  LL_GPIO_TogglePin(LD1_GPIO_Port,LD1_Pin);
		  ITM_SendChar(0x55);
		  ITM_SendChar('0');
		  ITM_SendChar('\n');
	  }
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
  }

 

 

 

Once you compile and run the debug, activate the SWO and limit the frequency at 2MHz (otherwise it will run at 12)

MD_1-1687436178095.png

After the program is loaded and the execution stops at the beginning of the main, add the toolbar for the SWV ITM Data Console:

MD_5-1687437990558.png

and add the port 0 on the settings:

MD_2-1687436299945.png

then press the "Start Trace" button before resuming the code execution:

MD_3-1687437584204.png

 

At this point you will see the output:

MD_4-1687437630766.png

and this is what the pin is doing:

MD_0-1687436141463.png

 

 

Hope this will help developers that stumbled on the same problem.

 

P.S. The ST-Link V3 can work also at 12MHz, as I set-up in the project in attach. You will need to remove the tick "Limit SWO clock" in the debugger configuration and change to 12000 the variable SWOSpeed into the main.c.

 

 

1 ACCEPTED SOLUTION

Accepted Solutions
MD
Associate II

I've tested the SWV at 12MHz and integrated that in my post above.

View solution in original post

4 REPLIES 4
MD
Associate II

I've tested the SWV at 12MHz and integrated that in my post above.

AScha.3
Chief III

well, i tried "your way" ... just get nothing than >hard fault. (on F303 cpu )

on cubeIDE 

AScha3_0-1687462674448.png

 

 

then removed some lines...then all.

nothing from itm.

using open ocd :

AScha3_0-1687462524971.png

 

so removed all , again set only:

 

 

 

 

/* USER CODE BEGIN 4 */

int __io_putchar(int ch)
{
    ITM_SendChar(ch);
    return (ch);
}

 

 

 

 

 

with:

AScha3_1-1687457556136.png

 

 

then it worked...

AScha3_0-1687457267796.png

try it. (but i can promise, it is more hit and hope game ! )

If you feel a post has answered your question, please click "Accept as Solution".
MD
Associate II

Well, "My way" is specific for a H7 core.

You are using an F3 core, which is an entirely different animal... Possibly that has the SWO settings enabled by default.

Hi,

no.

Tested and working on H5 (563), H7 (733, 743, 7A3) :

I have just enabled SWD+SWo in Cube, then in debug settings also: enable SWV . + set correct core frequemcy, it will run.

Then in main, just the

/* USER CODE BEGIN 4 */

int __io_putchar(int ch)
{
    ITM_SendChar(ch);
    return (ch);
}

+

In debug session then, pause, select SWV, ...as you show it on top. + "start trace" .

Then its working, thats all.

 

If you feel a post has answered your question, please click "Accept as Solution".