diff options
author | patacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3> | 2008-09-29 23:04:33 +0000 |
---|---|---|
committer | patacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3> | 2008-09-29 23:04:33 +0000 |
commit | 83200f4f501cff6378fc9655f5abeafc45cb3f93 (patch) | |
tree | fb5851a6e31b1f53481280b5b7b11441329ac67c /nuttx | |
parent | 20e184fe7d5c6b2e26f4267567d410b0e56fcddc (diff) | |
download | px4-nuttx-83200f4f501cff6378fc9655f5abeafc45cb3f93.tar.gz px4-nuttx-83200f4f501cff6378fc9655f5abeafc45cb3f93.tar.bz2 px4-nuttx-83200f4f501cff6378fc9655f5abeafc45cb3f93.zip |
Add more trace events
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@961 42af7a65-404d-4744-a932-0658087f49c3
Diffstat (limited to 'nuttx')
-rw-r--r-- | nuttx/arch/arm/src/lpc214x/lpc214x_usbdev.c | 13 | ||||
-rw-r--r-- | nuttx/include/nuttx/usbdev_trace.h | 92 |
2 files changed, 61 insertions, 44 deletions
diff --git a/nuttx/arch/arm/src/lpc214x/lpc214x_usbdev.c b/nuttx/arch/arm/src/lpc214x/lpc214x_usbdev.c index aed47a03a..8fc94c2c0 100644 --- a/nuttx/arch/arm/src/lpc214x/lpc214x_usbdev.c +++ b/nuttx/arch/arm/src/lpc214x/lpc214x_usbdev.c @@ -823,6 +823,8 @@ static void lpc214x_cancelrequests(struct lpc214x_ep_s *privep) { while (!sq_empty(&privep->reqlist)) { + usbtrace(TRACE_COMPLETE(privep->epphy), + ((struct lpc214x_req_s *)sq_peek(&privep->reqlist))->req.xfrd); lpc214x_reqcomplete(privep, -ESHUTDOWN); } } @@ -1103,6 +1105,7 @@ static inline void lpc214x_ep0setup(struct lpc214x_usbdev_s *priv) result = -EPROTO; } + usbtrace(TRACE_COMPLETE(ep0->epphy), privreq->req.xfrd); lpc214x_reqcomplete(ep0, result); } @@ -2011,7 +2014,6 @@ static int lpc214x_epdisable(FAR struct usbdev_ep_s *ep) reg &= ~mask; putreg32(reg, LPC214X_USBDEV_EPINTEN); - uvdbg("Disabled ep\n"); irqrestore(flags); return OK; } @@ -2179,6 +2181,7 @@ static int lpc214x_epsubmit(FAR struct usbdev_ep_s *ep, FAR struct usbdev_req_s { /* Nothing to transfer -- exit success, zero-bytes transferred */ + usbtrace(TRACE_COMPLETE(privep->epphy), privreq->req.xfrd); lpc214x_reqcomplete(privep, OK); goto success_notransfer; } @@ -2209,6 +2212,7 @@ static int lpc214x_epsubmit(FAR struct usbdev_ep_s *ep, FAR struct usbdev_req_s if (ret >= 0) { + usbtrace(TRACE_REQQUEUED(privep->epphy), privreq->req.len); sq_addlast(&privreq->sqe, &privep->reqlist); } @@ -2528,7 +2532,7 @@ void up_usbinitialize(void) usbtrace(TRACE_DEVINIT, 0); - /* Initialize the device state structure softwate EP priority */ + /* Initialize the device state structure */ memset(priv, 0, sizeof(struct lpc214x_usbdev_s)); priv->usbdev.ops = &g_devops; @@ -2632,12 +2636,13 @@ int usbdev_register(struct usbdevclass_driver_s *driver) int ret; usbtrace(TRACE_DEVREGISTER, 0); + #ifdef CONFIG_DEBUG if (!driver || !driver->ops.bind || !driver->ops.unbind || !driver->ops.disconnect || !driver->ops.setup) { - usbtrace(TRACE_ERROR(LPC214X_TRACEERR_INVALIDPARMS), 0); - return -EINVAL; + usbtrace(TRACE_ERROR(LPC214X_TRACEERR_INVALIDPARMS), 0); + return -EINVAL; } if (g_usbdev.driver) diff --git a/nuttx/include/nuttx/usbdev_trace.h b/nuttx/include/nuttx/usbdev_trace.h index 23922c451..1a2ecdbc1 100644 --- a/nuttx/include/nuttx/usbdev_trace.h +++ b/nuttx/include/nuttx/usbdev_trace.h @@ -48,62 +48,74 @@ ****************************************************************************/ #define TRACE_EVENT(id,num) ((uint16)(id)|(num)) -#define TRACE_CLASS(event) ((event)&0xff00) +#define TRACE_CLASS_ID(event) ((event)&0xff00) #define TRACE_INSTANCE(event) ((event)0x00ff) +/* Event class IDs */ + +#define TRACE_INIT_ID (0x0000) /* Initialization events */ +#define TRACE_EP_ID (0x0100) /* Endpoint API calls */ +#define TRACE_DEV_ID (0x0200) /* USB device API calls */ +#define TRACE_CLASS_ID (0x0300) /* USB class driver API calls */ +#define TRACE_INTENTRY_ID (0x0400) /* Interrupt handler entry */ +#define TRACE_INTDECODE_ID (0x0500) /* Decoded interrupt event */ +#define TRACE_INTEXIT_ID (0x0600) /* Interrupt handler exit */ +#define TRACE_REQQUEUED_ID (0x0700) /* Request queued */ +#define TRACE_READ_ID (0x0800) /* Read (OUT) action */ +#define TRACE_WRITE_ID (0x0900) /* Write (IN) action */ +#define TRACE_COMPLETE_ID (0x0a00) /* Request completed */ +#define TRACE_ERROR_ID (0x0b00) /* Error event */ + /* Initialization events */ -#define TRACE_INIT (0x0000) -#define TRACE_DEVINIT TRACE_EVENT(TRACE_INIT, 0x0001) -#define TRACE_DEVUNINIT TRACE_EVENT(TRACE_INIT, 0x0002) -#define TRACE_DEVREGISTER TRACE_EVENT(TRACE_INIT, 0x0003) -#define TRACE_DEVUNREGISTER TRACE_EVENT(TRACE_INIT, 0x0004) +#define TRACE_DEVINIT TRACE_EVENT(TRACE_INIT_ID, 0x0001) +#define TRACE_DEVUNINIT TRACE_EVENT(TRACE_INIT_ID, 0x0002) +#define TRACE_DEVREGISTER TRACE_EVENT(TRACE_INIT_ID, 0x0003) +#define TRACE_DEVUNREGISTER TRACE_EVENT(TRACE_INIT_ID, 0x0004) /* API calls (see usbdev.h) */ -#define TRACE_EP (0x0100) -#define TRACE_EPCONFIGURE TRACE_EVENT(TRACE_EP, 0x0001) -#define TRACE_EPDISABLE TRACE_EVENT(TRACE_EP, 0x0002) -#define TRACE_EPALLOCREQ TRACE_EVENT(TRACE_EP, 0x0003) -#define TRACE_EPFREEREQ TRACE_EVENT(TRACE_EP, 0x0004) -#define TRACE_EPALLOCBUFFER TRACE_EVENT(TRACE_EP, 0x0005) -#define TRACE_EPFREEBUFFER TRACE_EVENT(TRACE_EP, 0x0006) -#define TRACE_EPSUBMIT TRACE_EVENT(TRACE_EP, 0x0007) -#define TRACE_EPCANCEL TRACE_EVENT(TRACE_EP, 0x0008) -#define TRACE_EPSTALL TRACE_EVENT(TRACE_EP, 0x0009) -#define TRACE_EPRESUME TRACE_EVENT(TRACE_EP, 0x000a) - -#define TRACE_DEV (0x0200) -#define TRACE_DEVALLOCEP TRACE_EVENT(TRACE_DEV, 0x0001) -#define TRACE_DEVFREEEP TRACE_EVENT(TRACE_DEV, 0x0002) -#define TRACE_DEVGETFRAME TRACE_EVENT(TRACE_DEV, 0x0003) -#define TRACE_DEVWAKEUP TRACE_EVENT(TRACE_DEV, 0x0004) -#define TRACE_DEVSELFPOWERED TRACE_EVENT(TRACE_DEV, 0x0005) -#define TRACE_DEVPULLUP TRACE_EVENT(TRACE_DEV, 0x0006) - -#define TRACE_CLASS (0x0300) -#define TRACE_CLASSBIN TRACE_EVENT(TRACE_CLASS, 0x0001) -#define TRACE_CLASSUNBIND TRACE_EVENT(TRACE_CLASS, 0x0001) -#define TRACE_CLASSDISCONNECT TRACE_EVENT(TRACE_CLASS, 0x0001) -#define TRACE_CLASSSETUP TRACE_EVENT(TRACE_CLASS, 0x0001) -#define TRACE_CLASSSUSPEND TRACE_EVENT(TRACE_CLASS, 0x0001) -#define TRACE_CLASSRESUME TRACE_EVENT(TRACE_CLASS, 0x0001) +#define TRACE_EPCONFIGURE TRACE_EVENT(TRACE_EP_ID, 0x0001) +#define TRACE_EPDISABLE TRACE_EVENT(TRACE_EP_ID, 0x0002) +#define TRACE_EPALLOCREQ TRACE_EVENT(TRACE_EP_ID, 0x0003) +#define TRACE_EPFREEREQ TRACE_EVENT(TRACE_EP_ID, 0x0004) +#define TRACE_EPALLOCBUFFER TRACE_EVENT(TRACE_EP_ID, 0x0005) +#define TRACE_EPFREEBUFFER TRACE_EVENT(TRACE_EP_ID, 0x0006) +#define TRACE_EPSUBMIT TRACE_EVENT(TRACE_EP_ID, 0x0007) +#define TRACE_EPCANCEL TRACE_EVENT(TRACE_EP_ID, 0x0008) +#define TRACE_EPSTALL TRACE_EVENT(TRACE_EP_ID, 0x0009) +#define TRACE_EPRESUME TRACE_EVENT(TRACE_EP_ID, 0x000a) + +#define TRACE_DEVALLOCEP TRACE_EVENT(TRACE_DEV_ID, 0x0001) +#define TRACE_DEVFREEEP TRACE_EVENT(TRACE_DEV_ID, 0x0002) +#define TRACE_DEVGETFRAME TRACE_EVENT(TRACE_DEV_ID, 0x0003) +#define TRACE_DEVWAKEUP TRACE_EVENT(TRACE_DEV_ID, 0x0004) +#define TRACE_DEVSELFPOWERED TRACE_EVENT(TRACE_DEV_ID, 0x0005) +#define TRACE_DEVPULLUP TRACE_EVENT(TRACE_DEV_ID, 0x0006) + +#define TRACE_CLASSBIN TRACE_EVENT(TRACE_CLASS_ID, 0x0001) +#define TRACE_CLASSUNBIND TRACE_EVENT(TRACE_CLASS_ID, 0x0001) +#define TRACE_CLASSDISCONNECT TRACE_EVENT(TRACE_CLASS_ID, 0x0001) +#define TRACE_CLASSSETUP TRACE_EVENT(TRACE_CLASS_ID, 0x0001) +#define TRACE_CLASSSUSPEND TRACE_EVENT(TRACE_CLASS_ID, 0x0001) +#define TRACE_CLASSRESUME TRACE_EVENT(TRACE_CLASS_ID, 0x0001) /* Interrupt events -- id is hardware specific */ -#define TRACE_INTENTRY(id) TRACE_EVENT(0x0400, id) -#define TRACE_INTDECODE(id) TRACE_EVENT(0x0500, id) -#define TRACE_INTEXIT(id) TRACE_EVENT(0x0600, id) +#define TRACE_INTENTRY(id) TRACE_EVENT(TRACE_INTENTRY_ID, id) +#define TRACE_INTDECODE(id) TRACE_EVENT(TRACE_INTDECODE_ID, id) +#define TRACE_INTEXIT(id) TRACE_EVENT(TRACE_INTEXIT_ID, id) /* Data Transfer */ -#define TRACE_READ(ep) TRACE_EVENT(0x0700, ep) -#define TRACE_WRITE(ep) TRACE_EVENT(0x0800, ep) -#define TRACE_COMPLETE(ep) TRACE_EVENT(0x0900, ep) +#define TRACE_REQQUEUED(ep) TRACE_EVENT(TRACE_REQQUEUED_ID, ep) +#define TRACE_READ(ep) TRACE_EVENT(TRACE_READ_ID, ep) +#define TRACE_WRITE(ep) TRACE_EVENT(TRACE_WRITE_ID, ep) +#define TRACE_COMPLETE(ep) TRACE_EVENT(TRACE_COMPLETE_ID, ep) /* Error events -- id is specific to the driver */ -#define TRACE_ERROR(id) TRACE_EVENT(0x0700, id) +#define TRACE_ERROR(id) TRACE_EVENT(TRACE_ERROR_ID, id) /**************************************************************************** * Public Types |