aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/pvrusb2/pvrusb2-debug.h
blob: da6441b88f31af8ebae32a62533f9d6330f2823c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/*
 *  $Id$
 *
 *  Copyright (C) 2005 Mike Isely <isely@pobox.com>
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License
 *
 *  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.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 */
#ifndef __PVRUSB2_DEBUG_H
#define __PVRUSB2_DEBUG_H

extern int pvrusb2_debug;

#define pvr2_trace(msk, fmt, arg...) do {if(msk & pvrusb2_debug) printk(KERN_INFO "pvrusb2: " fmt "\n", ##arg); } while (0)

/* These are listed in *rough* order of decreasing usefulness and
   increasing noise level. */
#define PVR2_TRACE_INFO       (1 <<  0) /* Normal messages */
#define PVR2_TRACE_ERROR_LEGS (1 <<  1) /* error messages */
#define PVR2_TRACE_TOLERANCE  (1 <<  2) /* track tolerance-affected errors */
#define PVR2_TRACE_TRAP       (1 <<  3) /* Trap & report app misbehavior */
#define PVR2_TRACE_STD        (1 <<  4) /* Log video standard stuff */
#define PVR2_TRACE_INIT       (1 <<  5) /* misc initialization steps */
#define PVR2_TRACE_START_STOP (1 <<  6) /* Streaming start / stop */
#define PVR2_TRACE_CTL        (1 <<  7) /* commit of control changes */
#define PVR2_TRACE_DEBUG      (1 <<  8) /* Temporary debug code */
#define PVR2_TRACE_EEPROM     (1 <<  9) /* eeprom parsing / report */
#define PVR2_TRACE_STRUCT     (1 << 10) /* internal struct creation */
#define PVR2_TRACE_OPEN_CLOSE (1 << 11) /* application open / close */
#define PVR2_TRACE_CREG       (1 << 12) /* Main critical region entry / exit */
#define PVR2_TRACE_SYSFS      (1 << 13) /* Sysfs driven I/O */
#define PVR2_TRACE_FIRMWARE   (1 << 14) /* firmware upload actions */
#define PVR2_TRACE_CHIPS      (1 << 15) /* chip broadcast operation */
#define PVR2_TRACE_I2C        (1 << 16) /* I2C related stuff */
#define PVR2_TRACE_I2C_CMD    (1 << 17) /* Software commands to I2C modules */
#define PVR2_TRACE_I2C_CORE   (1 << 18) /* I2C core debugging */
#define PVR2_TRACE_I2C_TRAF   (1 << 19) /* I2C traffic through the adapter */
#define PVR2_TRACE_V4LIOCTL   (1 << 20) /* v4l ioctl details */
#define PVR2_TRACE_ENCODER    (1 << 21) /* mpeg2 encoder operation */
#define PVR2_TRACE_BUF_POOL   (1 << 22) /* Track buffer pool management */
#define PVR2_TRACE_BUF_FLOW   (1 << 23) /* Track buffer flow in system */
#define PVR2_TRACE_DATA_FLOW  (1 << 24) /* Track data flow */
#define PVR2_TRACE_DEBUGIFC   (1 << 25) /* Debug interface actions */
#define PVR2_TRACE_GPIO       (1 << 26) /* GPIO state bit changes */


#endif /* __PVRUSB2_HDW_INTERNAL_H */

/*
  Stuff for Emacs to see, in order to encourage consistent editing style:
  *** Local Variables: ***
  *** mode: c ***
  *** fill-column: 75 ***
  *** tab-width: 8 ***
  *** c-basic-offset: 8 ***
  *** End: ***
  */