SAMA5 TC: Debug instrumentation

This commit is contained in:
Gregory Nutt 2013-10-26 14:03:30 -06:00
parent 48ac4dcc2e
commit f090583cb2
2 changed files with 99 additions and 44 deletions

View File

@ -156,6 +156,7 @@ struct sam_tc_s
sem_t exclsem; /* Assures mutually exclusive access to TC */
uintptr_t base; /* Register base address */
uint8_t pid; /* Peripheral ID */
uint8_t tc; /* Timer/channel number (0 or 1) */
bool initialized; /* True: Timer data has been initialized */
/* Channels */
@ -182,9 +183,11 @@ static void sam_takesem(struct sam_tc_s *tc);
#define sam_givesem(tc) (sem_post(&tc->exclsem))
#ifdef CONFIG_SAMA5_TC_REGDEBUG
static void sam_regdump(struct sam_chan_s *chan, const char *msg);
static bool sam_checkreg(struct sam_tc_s *tc, bool wr, uint32_t regaddr,
uint32_t regval);
#else
# define sam_regdump(chan,msg)
# define sam_checkreg(tc,wr,regaddr,regval) (false)
#endif
@ -216,8 +219,9 @@ static const struct sam_tcconfig_s g_tc012config =
.tc = 0,
.channel =
{
[0] =
{
SAM_TC012_CHAN_BASE(0),
.base = SAM_TC012_CHAN_BASE(0),
#ifdef CONFIG_SAMA5_TC0_CLK0
.clkset = PIO_TC0_CLK,
#else
@ -234,8 +238,9 @@ static const struct sam_tcconfig_s g_tc012config =
.tiobset = 0,
#endif
},
[1] =
{
SAM_TC012_CHAN_BASE(1),
.base = SAM_TC012_CHAN_BASE(1),
#ifdef CONFIG_SAMA5_TC0_CLK1
.clkset = PIO_TC1_CLK,
#else
@ -252,8 +257,9 @@ static const struct sam_tcconfig_s g_tc012config =
.tiobset = 0,
#endif
},
[2] =
{
SAM_TC012_CHAN_BASE(2),
.base = SAM_TC012_CHAN_BASE(2),
#ifdef CONFIG_SAMA5_TC0_CLK2
.clkset = PIO_TC2_CLK,
#else
@ -283,8 +289,9 @@ static const struct sam_tcconfig_s g_tc345config =
.tc = 1,
.channel =
{
[0] =
{
SAM_TC345_CHAN_BASE(3),
.base = SAM_TC345_CHAN_BASE(3),
#ifdef CONFIG_SAMA5_TC1_CLK3
.clkset = PIO_TC3_CLK,
#else
@ -301,8 +308,9 @@ static const struct sam_tcconfig_s g_tc345config =
.tiobset = 0,
#endif
},
[1] =
{
SAM_TC345_CHAN_BASE(4),
.base = SAM_TC345_CHAN_BASE(4),
#ifdef CONFIG_SAMA5_TC1_CLK4
.clkset = PIO_TC4_CLK,
#else
@ -319,8 +327,9 @@ static const struct sam_tcconfig_s g_tc345config =
.tiobset = 0,
#endif
},
[2] =
{
SAM_TC345_CHAN_BASE(5),
.base = SAM_TC345_CHAN_BASE(5),
#ifdef CONFIG_SAMA5_TC1_CLK5
.clkset = PIO_TC5_CLK,
#else
@ -423,6 +432,46 @@ static void sam_takesem(struct sam_tc_s *tc)
}
}
/****************************************************************************
* Name: sam_regdump
*
* Description:
* Dump all timer/counter channel and global registers
*
* Input Parameters:
* chan - The timer/counter channel state
* msg - Message to print with the data
*
* Returned Value:
* None
*
****************************************************************************/
#ifdef CONFIG_SAMA5_TC_REGDEBUG
static void sam_regdump(struct sam_chan_s *chan, const char *msg)
{
struct sam_tc_s *tc = chan->tc;
uintptr_t base;
base = tc->base;
lldbg("TC%d [%08x]: %s\n", tc->tc, (int)base, msg);
lldbg(" BMR: %08x QIMR: %08x QISR: %08x WPMR: %08x\n",
getreg32(base+SAM_TC_BMR_OFFSET), getreg32(base+SAM_TC_QIMR_OFFSET),
getreg32(base+SAM_TC_QISR_OFFSET), getreg32(base+SAM_TC_WPMR_OFFSET));
base = chan->base;
lldbg("TC%d Channel %d [%08x]: %s\n", tc->tc, chan->chan, (int)base, msg);
lldbg(" CMR: %08x SSMR: %08x RAB: %08x CV: %08x\n",
getreg32(base+SAM_TC_CMR_OFFSET), getreg32(base+SAM_TC_SMMR_OFFSET),
getreg32(base+SAM_TC_RAB_OFFSET), getreg32(base+SAM_TC_CV_OFFSET));
lldbg(" RA: %08x RB: %08x RC: %08x SR: %08x\n",
getreg32(base+SAM_TC_RA_OFFSET), getreg32(base+SAM_TC_RB_OFFSET),
getreg32(base+SAM_TC_RC_OFFSET), getreg32(base+SAM_TC_SR_OFFSET));
lldbg(" IMR: %08x\n",
getreg32(base+SAM_TC_IMR_OFFSET));
}
#endif
/****************************************************************************
* Name: sam_checkreg
*
@ -648,6 +697,7 @@ static inline struct sam_chan_s *sam_tc_initialize(int channel)
memset(tc, 0, sizeof(struct sam_tc_s));
sem_init(&tc->exclsem, 0, 1);
tc->base = tcconfig->base;
tc->tc = channel < 3 ? 0 : 1;
tc->pid = tcconfig->pid;
/* Initialize the channels */
@ -729,6 +779,7 @@ static inline struct sam_chan_s *sam_tc_initialize(int channel)
/* And return the channel with the semaphore locked */
sam_regdump(chan, "Initialized");
return chan;
}
@ -782,6 +833,7 @@ TC_HANDLE sam_tc_allocate(int channel, int mode)
/* And set the requested mode */
sam_chan_putreg(chan, SAM_TC_CMR_OFFSET, mode);
sam_regdump(chan, "Allocated");
}
/* Return an opaque reference to the channel */
@ -842,6 +894,7 @@ void sam_tc_start(TC_HANDLE handle)
DEBUGASSERT(chan && chan->inuse);
sam_chan_putreg(chan, SAM_TC_CCR_OFFSET, TC_CCR_CLKEN | TC_CCR_SWTRG);
sam_regdump(chan, "Started");
}
/****************************************************************************
@ -865,6 +918,7 @@ void sam_tc_stop(TC_HANDLE handle)
DEBUGASSERT(chan && chan->inuse);
sam_chan_putreg(chan, SAM_TC_CCR_OFFSET, TC_CCR_CLKDIS);
sam_regdump(chan, "Stopped");
}
/****************************************************************************
@ -896,6 +950,7 @@ void sam_tc_setregister(TC_HANDLE handle, int reg, unsigned int div)
chan->chan, reg, TC_FREQUENCY, div, (unsigned int)regval);
sam_chan_putreg(chan, g_regoffset[reg], regval);
sam_regdump(chan, "Set register");
}
/****************************************************************************