Add more trace events

git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@961 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
patacongo 2008-09-29 23:04:33 +00:00
parent 60d8905398
commit 174a043a62
2 changed files with 59 additions and 42 deletions

View File

@ -823,6 +823,8 @@ static void lpc214x_cancelrequests(struct lpc214x_ep_s *privep)
{ {
while (!sq_empty(&privep->reqlist)) while (!sq_empty(&privep->reqlist))
{ {
usbtrace(TRACE_COMPLETE(privep->epphy),
((struct lpc214x_req_s *)sq_peek(&privep->reqlist))->req.xfrd);
lpc214x_reqcomplete(privep, -ESHUTDOWN); lpc214x_reqcomplete(privep, -ESHUTDOWN);
} }
} }
@ -1103,6 +1105,7 @@ static inline void lpc214x_ep0setup(struct lpc214x_usbdev_s *priv)
result = -EPROTO; result = -EPROTO;
} }
usbtrace(TRACE_COMPLETE(ep0->epphy), privreq->req.xfrd);
lpc214x_reqcomplete(ep0, result); lpc214x_reqcomplete(ep0, result);
} }
@ -2011,7 +2014,6 @@ static int lpc214x_epdisable(FAR struct usbdev_ep_s *ep)
reg &= ~mask; reg &= ~mask;
putreg32(reg, LPC214X_USBDEV_EPINTEN); putreg32(reg, LPC214X_USBDEV_EPINTEN);
uvdbg("Disabled ep\n");
irqrestore(flags); irqrestore(flags);
return OK; 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 */ /* Nothing to transfer -- exit success, zero-bytes transferred */
usbtrace(TRACE_COMPLETE(privep->epphy), privreq->req.xfrd);
lpc214x_reqcomplete(privep, OK); lpc214x_reqcomplete(privep, OK);
goto success_notransfer; 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) if (ret >= 0)
{ {
usbtrace(TRACE_REQQUEUED(privep->epphy), privreq->req.len);
sq_addlast(&privreq->sqe, &privep->reqlist); sq_addlast(&privreq->sqe, &privep->reqlist);
} }
@ -2528,7 +2532,7 @@ void up_usbinitialize(void)
usbtrace(TRACE_DEVINIT, 0); 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)); memset(priv, 0, sizeof(struct lpc214x_usbdev_s));
priv->usbdev.ops = &g_devops; priv->usbdev.ops = &g_devops;
@ -2632,12 +2636,13 @@ int usbdev_register(struct usbdevclass_driver_s *driver)
int ret; int ret;
usbtrace(TRACE_DEVREGISTER, 0); usbtrace(TRACE_DEVREGISTER, 0);
#ifdef CONFIG_DEBUG #ifdef CONFIG_DEBUG
if (!driver || !driver->ops.bind || !driver->ops.unbind || if (!driver || !driver->ops.bind || !driver->ops.unbind ||
!driver->ops.disconnect || !driver->ops.setup) !driver->ops.disconnect || !driver->ops.setup)
{ {
usbtrace(TRACE_ERROR(LPC214X_TRACEERR_INVALIDPARMS), 0); usbtrace(TRACE_ERROR(LPC214X_TRACEERR_INVALIDPARMS), 0);
return -EINVAL; return -EINVAL;
} }
if (g_usbdev.driver) if (g_usbdev.driver)

View File

@ -48,62 +48,74 @@
****************************************************************************/ ****************************************************************************/
#define TRACE_EVENT(id,num) ((uint16)(id)|(num)) #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) #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 */ /* Initialization events */
#define TRACE_INIT (0x0000) #define TRACE_DEVINIT TRACE_EVENT(TRACE_INIT_ID, 0x0001)
#define TRACE_DEVINIT TRACE_EVENT(TRACE_INIT, 0x0001) #define TRACE_DEVUNINIT TRACE_EVENT(TRACE_INIT_ID, 0x0002)
#define TRACE_DEVUNINIT TRACE_EVENT(TRACE_INIT, 0x0002) #define TRACE_DEVREGISTER TRACE_EVENT(TRACE_INIT_ID, 0x0003)
#define TRACE_DEVREGISTER TRACE_EVENT(TRACE_INIT, 0x0003) #define TRACE_DEVUNREGISTER TRACE_EVENT(TRACE_INIT_ID, 0x0004)
#define TRACE_DEVUNREGISTER TRACE_EVENT(TRACE_INIT, 0x0004)
/* API calls (see usbdev.h) */ /* API calls (see usbdev.h) */
#define TRACE_EP (0x0100) #define TRACE_EPCONFIGURE TRACE_EVENT(TRACE_EP_ID, 0x0001)
#define TRACE_EPCONFIGURE TRACE_EVENT(TRACE_EP, 0x0001) #define TRACE_EPDISABLE TRACE_EVENT(TRACE_EP_ID, 0x0002)
#define TRACE_EPDISABLE TRACE_EVENT(TRACE_EP, 0x0002) #define TRACE_EPALLOCREQ TRACE_EVENT(TRACE_EP_ID, 0x0003)
#define TRACE_EPALLOCREQ TRACE_EVENT(TRACE_EP, 0x0003) #define TRACE_EPFREEREQ TRACE_EVENT(TRACE_EP_ID, 0x0004)
#define TRACE_EPFREEREQ TRACE_EVENT(TRACE_EP, 0x0004) #define TRACE_EPALLOCBUFFER TRACE_EVENT(TRACE_EP_ID, 0x0005)
#define TRACE_EPALLOCBUFFER TRACE_EVENT(TRACE_EP, 0x0005) #define TRACE_EPFREEBUFFER TRACE_EVENT(TRACE_EP_ID, 0x0006)
#define TRACE_EPFREEBUFFER TRACE_EVENT(TRACE_EP, 0x0006) #define TRACE_EPSUBMIT TRACE_EVENT(TRACE_EP_ID, 0x0007)
#define TRACE_EPSUBMIT TRACE_EVENT(TRACE_EP, 0x0007) #define TRACE_EPCANCEL TRACE_EVENT(TRACE_EP_ID, 0x0008)
#define TRACE_EPCANCEL TRACE_EVENT(TRACE_EP, 0x0008) #define TRACE_EPSTALL TRACE_EVENT(TRACE_EP_ID, 0x0009)
#define TRACE_EPSTALL TRACE_EVENT(TRACE_EP, 0x0009) #define TRACE_EPRESUME TRACE_EVENT(TRACE_EP_ID, 0x000a)
#define TRACE_EPRESUME TRACE_EVENT(TRACE_EP, 0x000a)
#define TRACE_DEV (0x0200) #define TRACE_DEVALLOCEP TRACE_EVENT(TRACE_DEV_ID, 0x0001)
#define TRACE_DEVALLOCEP TRACE_EVENT(TRACE_DEV, 0x0001) #define TRACE_DEVFREEEP TRACE_EVENT(TRACE_DEV_ID, 0x0002)
#define TRACE_DEVFREEEP TRACE_EVENT(TRACE_DEV, 0x0002) #define TRACE_DEVGETFRAME TRACE_EVENT(TRACE_DEV_ID, 0x0003)
#define TRACE_DEVGETFRAME TRACE_EVENT(TRACE_DEV, 0x0003) #define TRACE_DEVWAKEUP TRACE_EVENT(TRACE_DEV_ID, 0x0004)
#define TRACE_DEVWAKEUP TRACE_EVENT(TRACE_DEV, 0x0004) #define TRACE_DEVSELFPOWERED TRACE_EVENT(TRACE_DEV_ID, 0x0005)
#define TRACE_DEVSELFPOWERED TRACE_EVENT(TRACE_DEV, 0x0005) #define TRACE_DEVPULLUP TRACE_EVENT(TRACE_DEV_ID, 0x0006)
#define TRACE_DEVPULLUP TRACE_EVENT(TRACE_DEV, 0x0006)
#define TRACE_CLASS (0x0300) #define TRACE_CLASSBIN TRACE_EVENT(TRACE_CLASS_ID, 0x0001)
#define TRACE_CLASSBIN TRACE_EVENT(TRACE_CLASS, 0x0001) #define TRACE_CLASSUNBIND TRACE_EVENT(TRACE_CLASS_ID, 0x0001)
#define TRACE_CLASSUNBIND TRACE_EVENT(TRACE_CLASS, 0x0001) #define TRACE_CLASSDISCONNECT TRACE_EVENT(TRACE_CLASS_ID, 0x0001)
#define TRACE_CLASSDISCONNECT TRACE_EVENT(TRACE_CLASS, 0x0001) #define TRACE_CLASSSETUP TRACE_EVENT(TRACE_CLASS_ID, 0x0001)
#define TRACE_CLASSSETUP TRACE_EVENT(TRACE_CLASS, 0x0001) #define TRACE_CLASSSUSPEND TRACE_EVENT(TRACE_CLASS_ID, 0x0001)
#define TRACE_CLASSSUSPEND TRACE_EVENT(TRACE_CLASS, 0x0001) #define TRACE_CLASSRESUME TRACE_EVENT(TRACE_CLASS_ID, 0x0001)
#define TRACE_CLASSRESUME TRACE_EVENT(TRACE_CLASS, 0x0001)
/* Interrupt events -- id is hardware specific */ /* Interrupt events -- id is hardware specific */
#define TRACE_INTENTRY(id) TRACE_EVENT(0x0400, id) #define TRACE_INTENTRY(id) TRACE_EVENT(TRACE_INTENTRY_ID, id)
#define TRACE_INTDECODE(id) TRACE_EVENT(0x0500, id) #define TRACE_INTDECODE(id) TRACE_EVENT(TRACE_INTDECODE_ID, id)
#define TRACE_INTEXIT(id) TRACE_EVENT(0x0600, id) #define TRACE_INTEXIT(id) TRACE_EVENT(TRACE_INTEXIT_ID, id)
/* Data Transfer */ /* Data Transfer */
#define TRACE_READ(ep) TRACE_EVENT(0x0700, ep) #define TRACE_REQQUEUED(ep) TRACE_EVENT(TRACE_REQQUEUED_ID, ep)
#define TRACE_WRITE(ep) TRACE_EVENT(0x0800, ep) #define TRACE_READ(ep) TRACE_EVENT(TRACE_READ_ID, ep)
#define TRACE_COMPLETE(ep) TRACE_EVENT(0x0900, 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 */ /* 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 * Public Types