First round of PWM driver debug changes

git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@4204 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
patacongo 2011-12-20 14:41:32 +00:00
parent 2ca8817c84
commit 209bffae9c
4 changed files with 60 additions and 4 deletions

View File

@ -70,6 +70,7 @@
* Pre-processor Definitions * Pre-processor Definitions
****************************************************************************/ ****************************************************************************/
/* Debug ********************************************************************/ /* Debug ********************************************************************/
/* Non-standard debug that may be enabled just for testing PWM */
#ifdef CONFIG_DEBUG_PWM #ifdef CONFIG_DEBUG_PWM
# define pwmdbg dbg # define pwmdbg dbg
@ -434,10 +435,13 @@ static int pwm_start(FAR struct pwm_lowerhalf_s *dev, FAR const struct pwm_info_
uint16_t ocmode1; uint16_t ocmode1;
uint16_t ocmode2; uint16_t ocmode2;
DEBUGASSERT(priv != NULL && info != NULL);
pwmvdbg("TIM%d channel: %d frequency: %d duty: %08x\n", pwmvdbg("TIM%d channel: %d frequency: %d duty: %08x\n",
priv->timid, priv->channel, info->frequency, info->duty); priv->timid, priv->channel, info->frequency, info->duty);
DEBUGASSERT(info->frequency > 0 && info->duty > 0 && info->duty < uitoub16(100));
/* Caculate optimal values for the timer prescaler and for the timer reload /* Calculate optimal values for the timer prescaler and for the timer reload
* register. If' frequency' is the desired frequency, then * register. If' frequency' is the desired frequency, then
* *
* reload = timclk / frequency * reload = timclk / frequency

View File

@ -521,3 +521,9 @@ Where <subdir> is one of the following:
CONFIG_NSH_IPADDR=(10<<24|0<<16|0<<8|2) : Target IP address 10.0.0.2 CONFIG_NSH_IPADDR=(10<<24|0<<16|0<<8|2) : Target IP address 10.0.0.2
CONFIG_NSH_DRIPADDR=(10<<24|0<<16|0<<8|1) : Host IP address 10.0.0.1 CONFIG_NSH_DRIPADDR=(10<<24|0<<16|0<<8|1) : Host IP address 10.0.0.1
NOTE: This example assumes that a network is connected. During its
initialization, it will try to negotiate the link speed. If you have
no network connected when you reset the board, there will be a long
delay (maybe 30 seconds?) before anything happens. That is the timeout
before the networking finally gives up and decides that no network is
available.

View File

@ -274,7 +274,7 @@
* FSMC must be disabled in this case! * FSMC must be disabled in this case!
*/ */
#define GPIO_TIM4_CH2 GPIO_TIM4_CH2_1 #define GPIO_TIM4_CH2 GPIO_TIM4_CH2_2
/************************************************************************************ /************************************************************************************
* Public Data * Public Data

View File

@ -66,6 +66,20 @@
/**************************************************************************** /****************************************************************************
* Pre-processor Definitions * Pre-processor Definitions
****************************************************************************/ ****************************************************************************/
/* Debug ********************************************************************/
/* Non-standard debug that may be enabled just for testing PWM */
#ifdef CONFIG_DEBUG_PWM
# define pwmdbg dbg
# define pwmvdbg vdbg
# define pwmlldbg lldbg
# define pwmllvdbg llvdbg
#else
# define pwmdbg(x...)
# define pwmvdbg(x...)
# define pwmlldbg(x...)
# define pwmllvdbg(x...)
#endif
/**************************************************************************** /****************************************************************************
* Private Type Definitions * Private Type Definitions
@ -128,6 +142,8 @@ static int pwm_open(FAR struct file *filep)
uint8_t tmp; uint8_t tmp;
int ret; int ret;
pwmvdbg("crefs: %d\n", upper->crefs);
/* Get exclusive access to the device structures */ /* Get exclusive access to the device structures */
ret = sem_wait(&upper->sem); ret = sem_wait(&upper->sem);
@ -159,6 +175,9 @@ static int pwm_open(FAR struct file *filep)
/* Yes.. perform one time hardware initialization. */ /* Yes.. perform one time hardware initialization. */
DEBUGASSERT(lower->ops->setup != NULL);
pwmvdbg("calling setup\n");
ret = lower->ops->setup(lower); ret = lower->ops->setup(lower);
if (ret < 0) if (ret < 0)
{ {
@ -192,6 +211,8 @@ static int pwm_close(FAR struct file *filep)
FAR struct pwm_upperhalf_s *upper = inode->i_private; FAR struct pwm_upperhalf_s *upper = inode->i_private;
int ret; int ret;
pwmvdbg("crefs: %d\n", upper->crefs);
/* Get exclusive access to the device structures */ /* Get exclusive access to the device structures */
ret = sem_wait(&upper->sem); ret = sem_wait(&upper->sem);
@ -219,6 +240,9 @@ static int pwm_close(FAR struct file *filep)
/* Disable the PWM device */ /* Disable the PWM device */
DEBUGASSERT(lower->ops->shutdown != NULL);
pwmvdbg("calling shutdown: %d\n");
lower->ops->shutdown(lower); lower->ops->shutdown(lower);
} }
ret = OK; ret = OK;
@ -275,6 +299,8 @@ static int pwm_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
/* Handle built-in ioctl commands */ /* Handle built-in ioctl commands */
pwmvdbg("cmd: %d arg: %ld\n", cmd, arg);
switch (cmd) switch (cmd)
{ {
/* PWMIOC_SETCHARACTERISTICS - Set the characteristics of the next pulsed /* PWMIOC_SETCHARACTERISTICS - Set the characteristics of the next pulsed
@ -290,6 +316,11 @@ static int pwm_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
case PWMIOC_SETCHARACTERISTICS: case PWMIOC_SETCHARACTERISTICS:
{ {
FAR const struct pwm_info_s *info = (FAR const struct pwm_info_s*)((uintptr_t)arg); FAR const struct pwm_info_s *info = (FAR const struct pwm_info_s*)((uintptr_t)arg);
DEBUGASSERT(info != NULL && lower->ops->start != NULL);
pwmvdbg("PWMIOC_SETCHARACTERISTICS frequency: %d duty: %08x started: %d\n",
info->frequency, info->duty, upper->started);
memcpy(&upper->info, info, sizeof(struct pwm_info_s)); memcpy(&upper->info, info, sizeof(struct pwm_info_s));
if (upper->started) if (upper->started)
{ {
@ -308,7 +339,11 @@ static int pwm_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
case PWMIOC_GETCHARACTERISTICS: case PWMIOC_GETCHARACTERISTICS:
{ {
FAR struct pwm_info_s *info = (FAR struct pwm_info_s*)((uintptr_t)arg); FAR struct pwm_info_s *info = (FAR struct pwm_info_s*)((uintptr_t)arg);
DEBUGASSERT(info != NULL);
memcpy(info, &upper->info, sizeof(struct pwm_info_s)); memcpy(info, &upper->info, sizeof(struct pwm_info_s));
pwmvdbg("PWMIOC_GETCHARACTERISTICS frequency: %d duty: %08x\n",
info->frequency, info->duty);
} }
break; break;
@ -320,6 +355,11 @@ static int pwm_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
case PWMIOC_START: case PWMIOC_START:
{ {
pwmvdbg("PWMIOC_START frequency: %d duty: %08x started: %d\n",
upper->info.frequency, upper->info.duty, upper->started);
DEBUGASSERT(lower->ops->start != NULL);
if (!upper->started) if (!upper->started)
{ {
ret = lower->ops->start(lower, &upper->info); ret = lower->ops->start(lower, &upper->info);
@ -335,6 +375,9 @@ static int pwm_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
case PWMIOC_STOP: case PWMIOC_STOP:
{ {
pwmvdbg("PWMIOC_STOP: started: %d\n", upper->started);
DEBUGASSERT(lower->ops->stop != NULL);
if (upper->started) if (upper->started)
{ {
ret = lower->ops->stop(lower); ret = lower->ops->stop(lower);
@ -347,6 +390,8 @@ static int pwm_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
default: default:
{ {
pwmvdbg("Forwarding unrecognized cmd: %d arg: %ld\n", cmd, arg);
DEBUGASSERT(lower->ops->ioctl != NULL);
ret = lower->ops->ioctl(lower, cmd, arg); ret = lower->ops->ioctl(lower, cmd, arg);
} }
break; break;
@ -392,6 +437,7 @@ int pwm_register(FAR const char *path, FAR struct pwm_lowerhalf_s *dev)
upper = (FAR struct pwm_upperhalf_s *)zalloc(sizeof(struct pwm_upperhalf_s)); upper = (FAR struct pwm_upperhalf_s *)zalloc(sizeof(struct pwm_upperhalf_s));
if (!upper) if (!upper)
{ {
pwmdbg("Allocation failed\n");
return -ENOMEM; return -ENOMEM;
} }
@ -402,8 +448,8 @@ int pwm_register(FAR const char *path, FAR struct pwm_lowerhalf_s *dev)
/* Register the PWM device */ /* Register the PWM device */
vdbg("Registering %s\n", path); pwmvdbg("Registering %s\n", path);
return register_driver(path, &g_pwmops, 0666, dev); return register_driver(path, &g_pwmops, 0666, upper);
} }
#endif /* CONFIG_PWM */ #endif /* CONFIG_PWM */