123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311 |
- /*
- * Copyright (c) 2014, The Linux Foundation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 and
- * only version 2 as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
- #undef TRACE_SYSTEM
- #define TRACE_SYSTEM ice40
- #if !defined(_TRACE_ICE40_H) || defined(TRACE_HEADER_MULTI_READ)
- #define _TRACE_ICE40_H
- #include <linux/tracepoint.h>
- #include <linux/usb.h>
- TRACE_EVENT(ice40_reg_write,
- TP_PROTO(u8 addr, u8 val, u8 cmd0, u8 cmd1, int ret),
- TP_ARGS(addr, val, cmd0, cmd1, ret),
- TP_STRUCT__entry(
- __field(u8, addr)
- __field(u8, val)
- __field(u8, cmd0)
- __field(u8, cmd1)
- __field(int, ret)
- ),
- TP_fast_assign(
- __entry->addr = addr;
- __entry->val = val;
- __entry->cmd0 = cmd0;
- __entry->cmd1 = cmd1;
- __entry->ret = ret;
- ),
- TP_printk("addr = %x val = %x cmd0 = %x cmd1 = %x ret = %d",
- __entry->addr, __entry->val, __entry->cmd0,
- __entry->cmd1, __entry->ret)
- );
- TRACE_EVENT(ice40_reg_read,
- TP_PROTO(u8 addr, u8 cmd0, int ret),
- TP_ARGS(addr, cmd0, ret),
- TP_STRUCT__entry(
- __field(u8, addr)
- __field(u8, cmd0)
- __field(int, ret)
- ),
- TP_fast_assign(
- __entry->addr = addr;
- __entry->cmd0 = cmd0;
- __entry->ret = ret;
- ),
- TP_printk("addr = %x cmd0 = %x ret = %x", __entry->addr,
- __entry->cmd0, __entry->ret)
- );
- TRACE_EVENT(ice40_hub_control,
- TP_PROTO(u16 req, u16 val, u16 index, u16 len, int ret),
- TP_ARGS(req, val, index, len, ret),
- TP_STRUCT__entry(
- __field(u16, req)
- __field(u16, val)
- __field(u16, index)
- __field(u16, len)
- __field(int, ret)
- ),
- TP_fast_assign(
- __entry->req = req;
- __entry->val = val;
- __entry->index = index;
- __entry->len = len;
- __entry->ret = ret;
- ),
- TP_printk("req = %x val = %x index = %x len = %x ret = %d",
- __entry->req, __entry->val, __entry->index,
- __entry->len, __entry->ret)
- );
- TRACE_EVENT(ice40_ep0,
- TP_PROTO(const char *state),
- TP_ARGS(state),
- TP_STRUCT__entry(
- __string(state, state)
- ),
- TP_fast_assign(
- __assign_str(state, state);
- ),
- TP_printk("ep0 state: %s", __get_str(state))
- );
- TRACE_EVENT(ice40_urb_enqueue,
- TP_PROTO(struct urb *urb),
- TP_ARGS(urb),
- TP_STRUCT__entry(
- __field(u16, epnum)
- __field(u8, dir)
- __field(u8, type)
- __field(u32, len)
- ),
- TP_fast_assign(
- __entry->epnum = usb_pipeendpoint(urb->pipe);
- __entry->dir = usb_urb_dir_in(urb);
- __entry->type = usb_pipebulk(urb->pipe);
- __entry->len = urb->transfer_buffer_length;
- ),
- TP_printk("URB_LOG: E: ep %d %s %s len %d", __entry->epnum,
- __entry->dir ? "In" : "Out",
- __entry->type ? "Bulk" : "ctrl",
- __entry->len)
- );
- TRACE_EVENT(ice40_urb_dequeue,
- TP_PROTO(struct urb *urb),
- TP_ARGS(urb),
- TP_STRUCT__entry(
- __field(u16, epnum)
- __field(u8, dir)
- __field(u8, type)
- __field(u32, len)
- __field(int, reason)
- ),
- TP_fast_assign(
- __entry->epnum = usb_pipeendpoint(urb->pipe);
- __entry->dir = usb_urb_dir_in(urb);
- __entry->type = usb_pipebulk(urb->pipe);
- __entry->len = urb->transfer_buffer_length;
- __entry->reason = urb->unlinked;
- ),
- TP_printk("URB_LOG: D: ep %d %s %s len %d reason %d",
- __entry->epnum,
- __entry->dir ? "In" : "Out",
- __entry->type ? "Bulk" : "ctrl",
- __entry->len, __entry->reason)
- );
- TRACE_EVENT(ice40_urb_done,
- TP_PROTO(struct urb *urb, int result),
- TP_ARGS(urb, result),
- TP_STRUCT__entry(
- __field(int, result)
- __field(u16, epnum)
- __field(u8, dir)
- __field(u8, type)
- __field(u32, len)
- __field(u32, actual)
- ),
- TP_fast_assign(
- __entry->result = result;
- __entry->epnum = usb_pipeendpoint(urb->pipe);
- __entry->dir = usb_urb_dir_in(urb);
- __entry->type = usb_pipebulk(urb->pipe);
- __entry->len = urb->transfer_buffer_length;
- __entry->actual = urb->actual_length;
- ),
- TP_printk("URB_LOG: C: ep %d %s %s len %d actual %d result %d",
- __entry->epnum, __entry->dir ? "In" : "Out",
- __entry->type ? "Bulk" : "ctrl", __entry->len,
- __entry->actual, __entry->result)
- );
- TRACE_EVENT(ice40_bus_suspend,
- TP_PROTO(u8 status),
- TP_ARGS(status),
- TP_STRUCT__entry(
- __field(u8, status)
- ),
- TP_fast_assign(
- __entry->status = status;
- ),
- TP_printk("bus_suspend status %d", __entry->status)
- );
- TRACE_EVENT(ice40_bus_resume,
- TP_PROTO(u8 status),
- TP_ARGS(status),
- TP_STRUCT__entry(
- __field(u8, status)
- ),
- TP_fast_assign(
- __entry->status = status;
- ),
- TP_printk("bus_resume status %d", __entry->status)
- );
- TRACE_EVENT(ice40_setup,
- TP_PROTO(const char *token, int ret),
- TP_ARGS(token, ret),
- TP_STRUCT__entry(
- __string(token, token)
- __field(int, ret)
- ),
- TP_fast_assign(
- __assign_str(token, token);
- __entry->ret = ret;
- ),
- TP_printk("Trace: SETUP %s ret %d",
- __get_str(token), __entry->ret)
- );
- TRACE_EVENT(ice40_in,
- TP_PROTO(u16 ep, const char *token, u8 len, u8 expected, int ret),
- TP_ARGS(ep, token, len, expected, ret),
- TP_STRUCT__entry(
- __field(u16, ep)
- __string(token, token)
- __field(u8, len)
- __field(u8, expected)
- __field(int, ret)
- ),
- TP_fast_assign(
- __entry->ep = ep;
- __assign_str(token, token);
- __entry->len = len;
- __entry->expected = expected;
- __entry->ret = ret;
- ),
- TP_printk("Trace: %d IN %s len %d expected %d ret %d",
- __entry->ep, __get_str(token),
- __entry->len, __entry->expected,
- __entry->ret)
- );
- TRACE_EVENT(ice40_out,
- TP_PROTO(u16 ep, const char *token, u8 len, int ret),
- TP_ARGS(ep, token, len, ret),
- TP_STRUCT__entry(
- __field(u16, ep)
- __string(token, token)
- __field(u8, len)
- __field(int, ret)
- ),
- TP_fast_assign(
- __entry->ep = ep;
- __assign_str(token, token);
- __entry->len = len;
- __entry->ret = ret;
- ),
- TP_printk("Trace: %d OUT %s len %d ret %d",
- __entry->ep, __get_str(token),
- __entry->len, __entry->ret)
- );
- #endif /* if !defined(_TRACE_ICE40_H) || defined(TRACE_HEADER_MULTI_READ) */
- /* This part must be outside protection */
- #include <trace/define_trace.h>
|