usb: xhci: add debugfs support for ep with stream
[linux-2.6-microblaze.git] / drivers / usb / host / xhci-debugfs.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3  * xhci-debugfs.h - xHCI debugfs interface
4  *
5  * Copyright (C) 2017 Intel Corporation
6  *
7  * Author: Lu Baolu <baolu.lu@linux.intel.com>
8  */
9
10 #ifndef __LINUX_XHCI_DEBUGFS_H
11 #define __LINUX_XHCI_DEBUGFS_H
12
13 #include <linux/debugfs.h>
14
15 #define DEBUGFS_NAMELEN 32
16
17 #define REG_CAPLENGTH                                   0x00
18 #define REG_HCSPARAMS1                                  0x04
19 #define REG_HCSPARAMS2                                  0x08
20 #define REG_HCSPARAMS3                                  0x0c
21 #define REG_HCCPARAMS1                                  0x10
22 #define REG_DOORBELLOFF                                 0x14
23 #define REG_RUNTIMEOFF                                  0x18
24 #define REG_HCCPARAMS2                                  0x1c
25
26 #define REG_USBCMD                                      0x00
27 #define REG_USBSTS                                      0x04
28 #define REG_PAGESIZE                                    0x08
29 #define REG_DNCTRL                                      0x14
30 #define REG_CRCR                                        0x18
31 #define REG_DCBAAP_LOW                                  0x30
32 #define REG_DCBAAP_HIGH                                 0x34
33 #define REG_CONFIG                                      0x38
34
35 #define REG_MFINDEX                                     0x00
36 #define REG_IR0_IMAN                                    0x20
37 #define REG_IR0_IMOD                                    0x24
38 #define REG_IR0_ERSTSZ                                  0x28
39 #define REG_IR0_ERSTBA_LOW                              0x30
40 #define REG_IR0_ERSTBA_HIGH                             0x34
41 #define REG_IR0_ERDP_LOW                                0x38
42 #define REG_IR0_ERDP_HIGH                               0x3c
43
44 #define REG_EXTCAP_USBLEGSUP                            0x00
45 #define REG_EXTCAP_USBLEGCTLSTS                         0x04
46
47 #define REG_EXTCAP_REVISION                             0x00
48 #define REG_EXTCAP_NAME                                 0x04
49 #define REG_EXTCAP_PORTINFO                             0x08
50 #define REG_EXTCAP_PORTTYPE                             0x0c
51 #define REG_EXTCAP_MANTISSA1                            0x10
52 #define REG_EXTCAP_MANTISSA2                            0x14
53 #define REG_EXTCAP_MANTISSA3                            0x18
54 #define REG_EXTCAP_MANTISSA4                            0x1c
55 #define REG_EXTCAP_MANTISSA5                            0x20
56 #define REG_EXTCAP_MANTISSA6                            0x24
57
58 #define REG_EXTCAP_DBC_CAPABILITY                       0x00
59 #define REG_EXTCAP_DBC_DOORBELL                         0x04
60 #define REG_EXTCAP_DBC_ERSTSIZE                         0x08
61 #define REG_EXTCAP_DBC_ERST_LOW                         0x10
62 #define REG_EXTCAP_DBC_ERST_HIGH                        0x14
63 #define REG_EXTCAP_DBC_ERDP_LOW                         0x18
64 #define REG_EXTCAP_DBC_ERDP_HIGH                        0x1c
65 #define REG_EXTCAP_DBC_CONTROL                          0x20
66 #define REG_EXTCAP_DBC_STATUS                           0x24
67 #define REG_EXTCAP_DBC_PORTSC                           0x28
68 #define REG_EXTCAP_DBC_CONT_LOW                         0x30
69 #define REG_EXTCAP_DBC_CONT_HIGH                        0x34
70 #define REG_EXTCAP_DBC_DEVINFO1                         0x38
71 #define REG_EXTCAP_DBC_DEVINFO2                         0x3c
72
73 #define dump_register(nm)                               \
74 {                                                       \
75         .name   = __stringify(nm),                      \
76         .offset = REG_ ##nm,                            \
77 }
78
79 struct xhci_regset {
80         char                    name[DEBUGFS_NAMELEN];
81         struct debugfs_regset32 regset;
82         size_t                  nregs;
83         struct list_head        list;
84 };
85
86 struct xhci_file_map {
87         const char              *name;
88         int                     (*show)(struct seq_file *s, void *unused);
89 };
90
91 struct xhci_ep_priv {
92         char                    name[DEBUGFS_NAMELEN];
93         struct dentry           *root;
94         struct xhci_stream_info *stream_info;
95         struct xhci_ring        *show_ring;
96         unsigned int            stream_id;
97 };
98
99 struct xhci_slot_priv {
100         char                    name[DEBUGFS_NAMELEN];
101         struct dentry           *root;
102         struct xhci_ep_priv     *eps[31];
103         struct xhci_virt_device *dev;
104 };
105
106 #ifdef CONFIG_DEBUG_FS
107 void xhci_debugfs_init(struct xhci_hcd *xhci);
108 void xhci_debugfs_exit(struct xhci_hcd *xhci);
109 void __init xhci_debugfs_create_root(void);
110 void __exit xhci_debugfs_remove_root(void);
111 void xhci_debugfs_create_slot(struct xhci_hcd *xhci, int slot_id);
112 void xhci_debugfs_remove_slot(struct xhci_hcd *xhci, int slot_id);
113 void xhci_debugfs_create_endpoint(struct xhci_hcd *xhci,
114                                   struct xhci_virt_device *virt_dev,
115                                   int ep_index);
116 void xhci_debugfs_remove_endpoint(struct xhci_hcd *xhci,
117                                   struct xhci_virt_device *virt_dev,
118                                   int ep_index);
119 void xhci_debugfs_create_stream_files(struct xhci_hcd *xhci,
120                                       struct xhci_virt_device *virt_dev,
121                                       int ep_index);
122 #else
123 static inline void xhci_debugfs_init(struct xhci_hcd *xhci) { }
124 static inline void xhci_debugfs_exit(struct xhci_hcd *xhci) { }
125 static inline void __init xhci_debugfs_create_root(void) { }
126 static inline void __exit xhci_debugfs_remove_root(void) { }
127 static inline void xhci_debugfs_create_slot(struct xhci_hcd *x, int s) { }
128 static inline void xhci_debugfs_remove_slot(struct xhci_hcd *x, int s) { }
129 static inline void
130 xhci_debugfs_create_endpoint(struct xhci_hcd *xhci,
131                              struct xhci_virt_device *virt_dev,
132                              int ep_index) { }
133 static inline void
134 xhci_debugfs_remove_endpoint(struct xhci_hcd *xhci,
135                              struct xhci_virt_device *virt_dev,
136                              int ep_index) { }
137 static inline void
138 xhci_debugfs_create_stream_files(struct xhci_hcd *xhci,
139                                  struct xhci_virt_device *virt_dev,
140                                  int ep_index) { }
141 #endif /* CONFIG_DEBUG_FS */
142
143 #endif /* __LINUX_XHCI_DEBUGFS_H */