Skip to content

Commit

Permalink
Unlock DWT registers only if necessary
Browse files Browse the repository at this point in the history
  • Loading branch information
Novakov committed Nov 9, 2024
1 parent 0779932 commit 7c231da
Showing 1 changed file with 15 additions and 1 deletion.
16 changes: 15 additions & 1 deletion libs/trace/include/orbcode/trace/dwt.h
Original file line number Diff line number Diff line change
Expand Up @@ -197,7 +197,21 @@ extern "C"
void DWTSetup(const DWTOptions* options)
{
CoreDebug->DEMCR |= CoreDebug_DEMCR_TRCENA_Msk; // Enable ITM and DWT
DWT->LAR = 0xC5ACCE55; // Unlock DWT access via magic number

// Some CPU do not have DWT lock registers
// All CoreSight compoents that might have lock, will have
// lock status register at offset 0xFB4
// lock access register at offset 0xFB0
// If locking is not implemented, lock status register will read as zero
// See: ARMv7-M Architecture Reference Manual, section D.1.1, table D1-2
volatile uint32_t* lockStatus = (volatile uint32_t*)&DWT + (0xFB4 / 4);
volatile uint32_t* lockAccess = (volatile uint32_t*)&DWT + (0xFB0 / 4);

if(*lockStatus != 0)
{
// lock status is not zero, meaning that unlock is necessary
*lockAccess = 0xC5ACCE55; // Unlock DWT access via magic number
}

uint32_t ctrl = 0;
ctrl |= (options->FoldedInstructionCounterEvent ? 1 : 0) << DWT_CTRL_FOLDEVTENA_Pos;
Expand Down

0 comments on commit 7c231da

Please sign in to comment.