dbg.h 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. /* Copyright Statement:
  2. *
  3. * This software/firmware and related documentation ("MediaTek Software") are
  4. * protected under relevant copyright laws. The information contained herein
  5. * is confidential and proprietary to MediaTek Inc. and/or its licensors.
  6. * Without the prior written permission of MediaTek inc. and/or its licensors,
  7. * any reproduction, modification, use or disclosure of MediaTek Software,
  8. * and information contained herein, in whole or in part, shall be strictly prohibited.
  9. *
  10. * MediaTek Inc. (C) 2010. All rights reserved.
  11. *
  12. * BY OPENING THIS FILE, RECEIVER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
  13. * THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
  14. * RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO RECEIVER ON
  15. * AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
  16. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
  17. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
  18. * NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
  19. * SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
  20. * SUPPLIED WITH THE MEDIATEK SOFTWARE, AND RECEIVER AGREES TO LOOK ONLY TO SUCH
  21. * THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. RECEIVER EXPRESSLY ACKNOWLEDGES
  22. * THAT IT IS RECEIVER'S SOLE RESPONSIBILITY TO OBTAIN FROM ANY THIRD PARTY ALL PROPER LICENSES
  23. * CONTAINED IN MEDIATEK SOFTWARE. MEDIATEK SHALL ALSO NOT BE RESPONSIBLE FOR ANY MEDIATEK
  24. * SOFTWARE RELEASES MADE TO RECEIVER'S SPECIFICATION OR TO CONFORM TO A PARTICULAR
  25. * STANDARD OR OPEN FORUM. RECEIVER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND
  26. * CUMULATIVE LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
  27. * AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
  28. * OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY RECEIVER TO
  29. * MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
  30. *
  31. * The following software/firmware and/or related documentation ("MediaTek Software")
  32. * have been modified by MediaTek Inc. All revisions are subject to any receiver's
  33. * applicable license agreements with MediaTek Inc.
  34. */
  35. #ifndef __MT_MSDC_DEUBG__
  36. #define __MT_MSDC_DEUBG__
  37. //==========================
  38. extern u32 sdio_pro_enable;
  39. /* for a type command, e.g. CMD53, 2 blocks */
  40. struct cmd_profile {
  41. u32 max_tc; /* Max tick count */
  42. u32 min_tc;
  43. u32 tot_tc; /* total tick count */
  44. u32 tot_bytes;
  45. u32 count; /* the counts of the command */
  46. };
  47. /* dump when total_tc and total_bytes */
  48. struct sdio_profile {
  49. u32 total_tc; /* total tick count of CMD52 and CMD53 */
  50. u32 total_tx_bytes; /* total bytes of CMD53 Tx */
  51. u32 total_rx_bytes; /* total bytes of CMD53 Rx */
  52. /*CMD52*/
  53. struct cmd_profile cmd52_tx;
  54. struct cmd_profile cmd52_rx;
  55. /*CMD53 in byte unit */
  56. struct cmd_profile cmd53_tx_byte[512];
  57. struct cmd_profile cmd53_rx_byte[512];
  58. /*CMD53 in block unit */
  59. struct cmd_profile cmd53_tx_blk[100];
  60. struct cmd_profile cmd53_rx_blk[100];
  61. };
  62. //==========================
  63. enum msdc_dbg {
  64. SD_TOOL_ZONE = 0,
  65. SD_TOOL_DMA_SIZE = 1,
  66. SD_TOOL_PM_ENABLE = 2,
  67. SD_TOOL_SDIO_PROFILE = 3,
  68. };
  69. /* Debug message event */
  70. #define DBG_EVT_NONE (0) /* No event */
  71. #define DBG_EVT_DMA (1 << 0) /* DMA related event */
  72. #define DBG_EVT_CMD (1 << 1) /* MSDC CMD related event */
  73. #define DBG_EVT_RSP (1 << 2) /* MSDC CMD RSP related event */
  74. #define DBG_EVT_INT (1 << 3) /* MSDC INT event */
  75. #define DBG_EVT_CFG (1 << 4) /* MSDC CFG event */
  76. #define DBG_EVT_FUC (1 << 5) /* Function event */
  77. #define DBG_EVT_OPS (1 << 6) /* Read/Write operation event */
  78. #define DBG_EVT_FIO (1 << 7) /* FIFO operation event */
  79. #define DBG_EVT_WRN (1 << 8) /* Warning event */
  80. #define DBG_EVT_PWR (1 << 9) /* Power event */
  81. #define DBG_EVT_ALL (0xffffffff)
  82. #define DBG_EVT_MASK (DBG_EVT_ALL)
  83. extern unsigned int sd_debug_zone[4];
  84. #define TAG "msdc"
  85. #if 0 /* +++ chhung */
  86. #define BUG_ON(x) \
  87. do { \
  88. if (x) { \
  89. printk("[BUG] %s LINE:%d FILE:%s\n", #x, __LINE__, __FILE__); \
  90. while (1) \
  91. ; \
  92. } \
  93. } while (0)
  94. #endif /* end of +++ */
  95. #define N_MSG(evt, fmt, args...)
  96. /*
  97. do { \
  98. if ((DBG_EVT_##evt) & sd_debug_zone[host->id]) { \
  99. printk(KERN_ERR TAG"%d -> "fmt" <- %s() : L<%d> PID<%s><0x%x>\n", \
  100. host->id, ##args , __FUNCTION__, __LINE__, current->comm, current->pid); \
  101. } \
  102. } while(0)
  103. */
  104. #define ERR_MSG(fmt, args...) \
  105. do { \
  106. printk(KERN_ERR TAG"%d -> "fmt" <- %s() : L<%d> PID<%s><0x%x>\n", \
  107. host->id, ##args, __FUNCTION__, __LINE__, current->comm, current->pid); \
  108. } while (0);
  109. #if 1
  110. //defined CONFIG_MTK_MMC_CD_POLL
  111. #define INIT_MSG(fmt, args...)
  112. #define IRQ_MSG(fmt, args...)
  113. #else
  114. #define INIT_MSG(fmt, args...) \
  115. do { \
  116. printk(KERN_ERR TAG"%d -> "fmt" <- %s() : L<%d> PID<%s><0x%x>\n", \
  117. host->id, ##args, __FUNCTION__, __LINE__, current->comm, current->pid); \
  118. } while (0);
  119. /* PID in ISR in not corrent */
  120. #define IRQ_MSG(fmt, args...) \
  121. do { \
  122. printk(KERN_ERR TAG"%d -> "fmt" <- %s() : L<%d>\n", \
  123. host->id, ##args, __FUNCTION__, __LINE__); \
  124. } while (0);
  125. #endif
  126. void msdc_debug_proc_init(void);
  127. #if 0 /* --- chhung */
  128. void msdc_init_gpt(void);
  129. extern void GPT_GetCounter64(UINT32 *cntL32, UINT32 *cntH32);
  130. #endif /* end of --- */
  131. u32 msdc_time_calc(u32 old_L32, u32 old_H32, u32 new_L32, u32 new_H32);
  132. void msdc_performance(u32 opcode, u32 sizes, u32 bRx, u32 ticks);
  133. #endif