xeye_ atsu
/
I2S_AIC23B_32khz_wavtest
I2S_Example/debug_frmwrk.c@0:63ed631d8c3a, 2011-01-21 (annotated)
- Committer:
- lynxeyed_atsu
- Date:
- Fri Jan 21 08:39:48 2011 +0000
- Revision:
- 0:63ed631d8c3a
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
lynxeyed_atsu | 0:63ed631d8c3a | 1 | /***********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 2 | * @file debug_frmwrk.c |
lynxeyed_atsu | 0:63ed631d8c3a | 3 | * @brief Contains some utilities that used for debugging through UART |
lynxeyed_atsu | 0:63ed631d8c3a | 4 | * @version 2.0 |
lynxeyed_atsu | 0:63ed631d8c3a | 5 | * @date 21. May. 2010 |
lynxeyed_atsu | 0:63ed631d8c3a | 6 | * @author NXP MCU SW Application Team |
lynxeyed_atsu | 0:63ed631d8c3a | 7 | *---------------------------------------------------------------------------- |
lynxeyed_atsu | 0:63ed631d8c3a | 8 | * Software that is described herein is for illustrative purposes only |
lynxeyed_atsu | 0:63ed631d8c3a | 9 | * which provides customers with programming information regarding the |
lynxeyed_atsu | 0:63ed631d8c3a | 10 | * products. This software is supplied "AS IS" without any warranties. |
lynxeyed_atsu | 0:63ed631d8c3a | 11 | * NXP Semiconductors assumes no responsibility or liability for the |
lynxeyed_atsu | 0:63ed631d8c3a | 12 | * use of the software, conveys no license or title under any patent, |
lynxeyed_atsu | 0:63ed631d8c3a | 13 | * copyright, or mask work right to the product. NXP Semiconductors |
lynxeyed_atsu | 0:63ed631d8c3a | 14 | * reserves the right to make changes in the software without |
lynxeyed_atsu | 0:63ed631d8c3a | 15 | * notification. NXP Semiconductors also make no representation or |
lynxeyed_atsu | 0:63ed631d8c3a | 16 | * warranty that such application will be suitable for the specified |
lynxeyed_atsu | 0:63ed631d8c3a | 17 | * use without further testing or modification. |
lynxeyed_atsu | 0:63ed631d8c3a | 18 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 19 | |
lynxeyed_atsu | 0:63ed631d8c3a | 20 | #include "debug_frmwrk.h" |
lynxeyed_atsu | 0:63ed631d8c3a | 21 | #include "lpc17xx_pinsel.h" |
lynxeyed_atsu | 0:63ed631d8c3a | 22 | |
lynxeyed_atsu | 0:63ed631d8c3a | 23 | /* If this source file built with example, the LPC17xx FW library configuration |
lynxeyed_atsu | 0:63ed631d8c3a | 24 | * file in each example directory ("lpc17xx_libcfg.h") must be included, |
lynxeyed_atsu | 0:63ed631d8c3a | 25 | * otherwise the default FW library configuration file must be included instead |
lynxeyed_atsu | 0:63ed631d8c3a | 26 | */ |
lynxeyed_atsu | 0:63ed631d8c3a | 27 | #ifdef __BUILD_WITH_EXAMPLE__ |
lynxeyed_atsu | 0:63ed631d8c3a | 28 | #include "lpc17xx_libcfg.h" |
lynxeyed_atsu | 0:63ed631d8c3a | 29 | #else |
lynxeyed_atsu | 0:63ed631d8c3a | 30 | #include "lpc17xx_libcfg_default.h" |
lynxeyed_atsu | 0:63ed631d8c3a | 31 | #endif /* __BUILD_WITH_EXAMPLE__ */ |
lynxeyed_atsu | 0:63ed631d8c3a | 32 | |
lynxeyed_atsu | 0:63ed631d8c3a | 33 | #ifdef _DBGFWK |
lynxeyed_atsu | 0:63ed631d8c3a | 34 | /* Debug framework */ |
lynxeyed_atsu | 0:63ed631d8c3a | 35 | |
lynxeyed_atsu | 0:63ed631d8c3a | 36 | void (*_db_msg)(LPC_UART_TypeDef *UARTx, const void *s); |
lynxeyed_atsu | 0:63ed631d8c3a | 37 | void (*_db_msg_)(LPC_UART_TypeDef *UARTx, const void *s); |
lynxeyed_atsu | 0:63ed631d8c3a | 38 | void (*_db_char)(LPC_UART_TypeDef *UARTx, uint8_t ch); |
lynxeyed_atsu | 0:63ed631d8c3a | 39 | void (*_db_dec)(LPC_UART_TypeDef *UARTx, uint8_t decn); |
lynxeyed_atsu | 0:63ed631d8c3a | 40 | void (*_db_dec_16)(LPC_UART_TypeDef *UARTx, uint16_t decn); |
lynxeyed_atsu | 0:63ed631d8c3a | 41 | void (*_db_dec_32)(LPC_UART_TypeDef *UARTx, uint32_t decn); |
lynxeyed_atsu | 0:63ed631d8c3a | 42 | void (*_db_hex)(LPC_UART_TypeDef *UARTx, uint8_t hexn); |
lynxeyed_atsu | 0:63ed631d8c3a | 43 | void (*_db_hex_16)(LPC_UART_TypeDef *UARTx, uint16_t hexn); |
lynxeyed_atsu | 0:63ed631d8c3a | 44 | void (*_db_hex_32)(LPC_UART_TypeDef *UARTx, uint32_t hexn); |
lynxeyed_atsu | 0:63ed631d8c3a | 45 | uint8_t (*_db_get_char)(LPC_UART_TypeDef *UARTx); |
lynxeyed_atsu | 0:63ed631d8c3a | 46 | |
lynxeyed_atsu | 0:63ed631d8c3a | 47 | |
lynxeyed_atsu | 0:63ed631d8c3a | 48 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 49 | * @brief Puts a character to UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 50 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 51 | * @param[in] ch Character to put |
lynxeyed_atsu | 0:63ed631d8c3a | 52 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 53 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 54 | void UARTPutChar (LPC_UART_TypeDef *UARTx, uint8_t ch) |
lynxeyed_atsu | 0:63ed631d8c3a | 55 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 56 | UART_Send(UARTx, &ch, 1, BLOCKING); |
lynxeyed_atsu | 0:63ed631d8c3a | 57 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 58 | |
lynxeyed_atsu | 0:63ed631d8c3a | 59 | |
lynxeyed_atsu | 0:63ed631d8c3a | 60 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 61 | * @brief Get a character to UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 62 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 63 | * @return character value that returned |
lynxeyed_atsu | 0:63ed631d8c3a | 64 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 65 | uint8_t UARTGetChar (LPC_UART_TypeDef *UARTx) |
lynxeyed_atsu | 0:63ed631d8c3a | 66 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 67 | uint8_t tmp = 0; |
lynxeyed_atsu | 0:63ed631d8c3a | 68 | UART_Receive(UARTx, &tmp, 1, BLOCKING); |
lynxeyed_atsu | 0:63ed631d8c3a | 69 | return(tmp); |
lynxeyed_atsu | 0:63ed631d8c3a | 70 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 71 | |
lynxeyed_atsu | 0:63ed631d8c3a | 72 | |
lynxeyed_atsu | 0:63ed631d8c3a | 73 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 74 | * @brief Puts a string to UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 75 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 76 | * @param[in] str string to put |
lynxeyed_atsu | 0:63ed631d8c3a | 77 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 78 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 79 | void UARTPuts(LPC_UART_TypeDef *UARTx, const void *str) |
lynxeyed_atsu | 0:63ed631d8c3a | 80 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 81 | uint8_t *s = (uint8_t *) str; |
lynxeyed_atsu | 0:63ed631d8c3a | 82 | |
lynxeyed_atsu | 0:63ed631d8c3a | 83 | while (*s) |
lynxeyed_atsu | 0:63ed631d8c3a | 84 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 85 | UARTPutChar(UARTx, *s++); |
lynxeyed_atsu | 0:63ed631d8c3a | 86 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 87 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 88 | |
lynxeyed_atsu | 0:63ed631d8c3a | 89 | |
lynxeyed_atsu | 0:63ed631d8c3a | 90 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 91 | * @brief Puts a string to UART port and print new line |
lynxeyed_atsu | 0:63ed631d8c3a | 92 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 93 | * @param[in] str String to put |
lynxeyed_atsu | 0:63ed631d8c3a | 94 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 95 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 96 | void UARTPuts_(LPC_UART_TypeDef *UARTx, const void *str) |
lynxeyed_atsu | 0:63ed631d8c3a | 97 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 98 | UARTPuts (UARTx, str); |
lynxeyed_atsu | 0:63ed631d8c3a | 99 | UARTPuts (UARTx, "\n\r"); |
lynxeyed_atsu | 0:63ed631d8c3a | 100 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 101 | |
lynxeyed_atsu | 0:63ed631d8c3a | 102 | |
lynxeyed_atsu | 0:63ed631d8c3a | 103 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 104 | * @brief Puts a decimal number to UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 105 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 106 | * @param[in] decnum Decimal number (8-bit long) |
lynxeyed_atsu | 0:63ed631d8c3a | 107 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 108 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 109 | void UARTPutDec(LPC_UART_TypeDef *UARTx, uint8_t decnum) |
lynxeyed_atsu | 0:63ed631d8c3a | 110 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 111 | uint8_t c1=decnum%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 112 | uint8_t c2=(decnum/10)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 113 | uint8_t c3=(decnum/100)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 114 | UARTPutChar(UARTx, '0'+c3); |
lynxeyed_atsu | 0:63ed631d8c3a | 115 | UARTPutChar(UARTx, '0'+c2); |
lynxeyed_atsu | 0:63ed631d8c3a | 116 | UARTPutChar(UARTx, '0'+c1); |
lynxeyed_atsu | 0:63ed631d8c3a | 117 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 118 | |
lynxeyed_atsu | 0:63ed631d8c3a | 119 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 120 | * @brief Puts a decimal number to UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 121 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 122 | * @param[in] decnum Decimal number (8-bit long) |
lynxeyed_atsu | 0:63ed631d8c3a | 123 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 124 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 125 | void UARTPutDec16(LPC_UART_TypeDef *UARTx, uint16_t decnum) |
lynxeyed_atsu | 0:63ed631d8c3a | 126 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 127 | uint8_t c1=decnum%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 128 | uint8_t c2=(decnum/10)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 129 | uint8_t c3=(decnum/100)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 130 | uint8_t c4=(decnum/1000)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 131 | uint8_t c5=(decnum/10000)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 132 | UARTPutChar(UARTx, '0'+c5); |
lynxeyed_atsu | 0:63ed631d8c3a | 133 | UARTPutChar(UARTx, '0'+c4); |
lynxeyed_atsu | 0:63ed631d8c3a | 134 | UARTPutChar(UARTx, '0'+c3); |
lynxeyed_atsu | 0:63ed631d8c3a | 135 | UARTPutChar(UARTx, '0'+c2); |
lynxeyed_atsu | 0:63ed631d8c3a | 136 | UARTPutChar(UARTx, '0'+c1); |
lynxeyed_atsu | 0:63ed631d8c3a | 137 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 138 | |
lynxeyed_atsu | 0:63ed631d8c3a | 139 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 140 | * @brief Puts a decimal number to UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 141 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 142 | * @param[in] decnum Decimal number (8-bit long) |
lynxeyed_atsu | 0:63ed631d8c3a | 143 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 144 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 145 | void UARTPutDec32(LPC_UART_TypeDef *UARTx, uint32_t decnum) |
lynxeyed_atsu | 0:63ed631d8c3a | 146 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 147 | uint8_t c1=decnum%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 148 | uint8_t c2=(decnum/10)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 149 | uint8_t c3=(decnum/100)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 150 | uint8_t c4=(decnum/1000)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 151 | uint8_t c5=(decnum/10000)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 152 | uint8_t c6=(decnum/100000)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 153 | uint8_t c7=(decnum/1000000)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 154 | uint8_t c8=(decnum/10000000)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 155 | uint8_t c9=(decnum/100000000)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 156 | uint8_t c10=(decnum/100000000)%10; |
lynxeyed_atsu | 0:63ed631d8c3a | 157 | UARTPutChar(UARTx, '0'+c10); |
lynxeyed_atsu | 0:63ed631d8c3a | 158 | UARTPutChar(UARTx, '0'+c9); |
lynxeyed_atsu | 0:63ed631d8c3a | 159 | UARTPutChar(UARTx, '0'+c8); |
lynxeyed_atsu | 0:63ed631d8c3a | 160 | UARTPutChar(UARTx, '0'+c7); |
lynxeyed_atsu | 0:63ed631d8c3a | 161 | UARTPutChar(UARTx, '0'+c6); |
lynxeyed_atsu | 0:63ed631d8c3a | 162 | UARTPutChar(UARTx, '0'+c5); |
lynxeyed_atsu | 0:63ed631d8c3a | 163 | UARTPutChar(UARTx, '0'+c4); |
lynxeyed_atsu | 0:63ed631d8c3a | 164 | UARTPutChar(UARTx, '0'+c3); |
lynxeyed_atsu | 0:63ed631d8c3a | 165 | UARTPutChar(UARTx, '0'+c2); |
lynxeyed_atsu | 0:63ed631d8c3a | 166 | UARTPutChar(UARTx, '0'+c1); |
lynxeyed_atsu | 0:63ed631d8c3a | 167 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 168 | |
lynxeyed_atsu | 0:63ed631d8c3a | 169 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 170 | * @brief Puts a hex number to UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 171 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 172 | * @param[in] hexnum Hex number (8-bit long) |
lynxeyed_atsu | 0:63ed631d8c3a | 173 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 174 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 175 | void UARTPutHex (LPC_UART_TypeDef *UARTx, uint8_t hexnum) |
lynxeyed_atsu | 0:63ed631d8c3a | 176 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 177 | uint8_t nibble, i; |
lynxeyed_atsu | 0:63ed631d8c3a | 178 | |
lynxeyed_atsu | 0:63ed631d8c3a | 179 | UARTPuts(UARTx, "0x"); |
lynxeyed_atsu | 0:63ed631d8c3a | 180 | i = 1; |
lynxeyed_atsu | 0:63ed631d8c3a | 181 | do { |
lynxeyed_atsu | 0:63ed631d8c3a | 182 | nibble = (hexnum >> (4*i)) & 0x0F; |
lynxeyed_atsu | 0:63ed631d8c3a | 183 | UARTPutChar(UARTx, (nibble > 9) ? ('A' + nibble - 10) : ('0' + nibble)); |
lynxeyed_atsu | 0:63ed631d8c3a | 184 | } while (i--); |
lynxeyed_atsu | 0:63ed631d8c3a | 185 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 186 | |
lynxeyed_atsu | 0:63ed631d8c3a | 187 | |
lynxeyed_atsu | 0:63ed631d8c3a | 188 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 189 | * @brief Puts a hex number to UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 190 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 191 | * @param[in] hexnum Hex number (16-bit long) |
lynxeyed_atsu | 0:63ed631d8c3a | 192 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 193 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 194 | void UARTPutHex16 (LPC_UART_TypeDef *UARTx, uint16_t hexnum) |
lynxeyed_atsu | 0:63ed631d8c3a | 195 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 196 | uint8_t nibble, i; |
lynxeyed_atsu | 0:63ed631d8c3a | 197 | |
lynxeyed_atsu | 0:63ed631d8c3a | 198 | UARTPuts(UARTx, "0x"); |
lynxeyed_atsu | 0:63ed631d8c3a | 199 | i = 3; |
lynxeyed_atsu | 0:63ed631d8c3a | 200 | do { |
lynxeyed_atsu | 0:63ed631d8c3a | 201 | nibble = (hexnum >> (4*i)) & 0x0F; |
lynxeyed_atsu | 0:63ed631d8c3a | 202 | UARTPutChar(UARTx, (nibble > 9) ? ('A' + nibble - 10) : ('0' + nibble)); |
lynxeyed_atsu | 0:63ed631d8c3a | 203 | } while (i--); |
lynxeyed_atsu | 0:63ed631d8c3a | 204 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 205 | |
lynxeyed_atsu | 0:63ed631d8c3a | 206 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 207 | * @brief Puts a hex number to UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 208 | * @param[in] UARTx Pointer to UART peripheral |
lynxeyed_atsu | 0:63ed631d8c3a | 209 | * @param[in] hexnum Hex number (32-bit long) |
lynxeyed_atsu | 0:63ed631d8c3a | 210 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 211 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 212 | void UARTPutHex32 (LPC_UART_TypeDef *UARTx, uint32_t hexnum) |
lynxeyed_atsu | 0:63ed631d8c3a | 213 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 214 | uint8_t nibble, i; |
lynxeyed_atsu | 0:63ed631d8c3a | 215 | |
lynxeyed_atsu | 0:63ed631d8c3a | 216 | UARTPuts(UARTx, "0x"); |
lynxeyed_atsu | 0:63ed631d8c3a | 217 | i = 7; |
lynxeyed_atsu | 0:63ed631d8c3a | 218 | do { |
lynxeyed_atsu | 0:63ed631d8c3a | 219 | nibble = (hexnum >> (4*i)) & 0x0F; |
lynxeyed_atsu | 0:63ed631d8c3a | 220 | UARTPutChar(UARTx, (nibble > 9) ? ('A' + nibble - 10) : ('0' + nibble)); |
lynxeyed_atsu | 0:63ed631d8c3a | 221 | } while (i--); |
lynxeyed_atsu | 0:63ed631d8c3a | 222 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 223 | |
lynxeyed_atsu | 0:63ed631d8c3a | 224 | ///*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 225 | // * @brief print function that supports format as same as printf() |
lynxeyed_atsu | 0:63ed631d8c3a | 226 | // * function of <stdio.h> library |
lynxeyed_atsu | 0:63ed631d8c3a | 227 | // * @param[in] None |
lynxeyed_atsu | 0:63ed631d8c3a | 228 | // * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 229 | // **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 230 | //void _printf (const char *format, ...) |
lynxeyed_atsu | 0:63ed631d8c3a | 231 | //{ |
lynxeyed_atsu | 0:63ed631d8c3a | 232 | // static char buffer[512 + 1]; |
lynxeyed_atsu | 0:63ed631d8c3a | 233 | // va_list vArgs; |
lynxeyed_atsu | 0:63ed631d8c3a | 234 | // char *tmp; |
lynxeyed_atsu | 0:63ed631d8c3a | 235 | // va_start(vArgs, format); |
lynxeyed_atsu | 0:63ed631d8c3a | 236 | // vsprintf((char *)buffer, (char const *)format, vArgs); |
lynxeyed_atsu | 0:63ed631d8c3a | 237 | // va_end(vArgs); |
lynxeyed_atsu | 0:63ed631d8c3a | 238 | // |
lynxeyed_atsu | 0:63ed631d8c3a | 239 | // _DBG(buffer); |
lynxeyed_atsu | 0:63ed631d8c3a | 240 | //} |
lynxeyed_atsu | 0:63ed631d8c3a | 241 | |
lynxeyed_atsu | 0:63ed631d8c3a | 242 | /*********************************************************************//** |
lynxeyed_atsu | 0:63ed631d8c3a | 243 | * @brief Initialize Debug frame work through initializing UART port |
lynxeyed_atsu | 0:63ed631d8c3a | 244 | * @param[in] None |
lynxeyed_atsu | 0:63ed631d8c3a | 245 | * @return None |
lynxeyed_atsu | 0:63ed631d8c3a | 246 | **********************************************************************/ |
lynxeyed_atsu | 0:63ed631d8c3a | 247 | void debug_frmwrk_init(void) |
lynxeyed_atsu | 0:63ed631d8c3a | 248 | { |
lynxeyed_atsu | 0:63ed631d8c3a | 249 | UART_CFG_Type UARTConfigStruct; |
lynxeyed_atsu | 0:63ed631d8c3a | 250 | PINSEL_CFG_Type PinCfg; |
lynxeyed_atsu | 0:63ed631d8c3a | 251 | |
lynxeyed_atsu | 0:63ed631d8c3a | 252 | #if (USED_UART_DEBUG_PORT==0) |
lynxeyed_atsu | 0:63ed631d8c3a | 253 | /* |
lynxeyed_atsu | 0:63ed631d8c3a | 254 | * Initialize UART0 pin connect |
lynxeyed_atsu | 0:63ed631d8c3a | 255 | */ |
lynxeyed_atsu | 0:63ed631d8c3a | 256 | PinCfg.Funcnum = 1; |
lynxeyed_atsu | 0:63ed631d8c3a | 257 | PinCfg.OpenDrain = 0; |
lynxeyed_atsu | 0:63ed631d8c3a | 258 | PinCfg.Pinmode = 0; |
lynxeyed_atsu | 0:63ed631d8c3a | 259 | PinCfg.Pinnum = 2; |
lynxeyed_atsu | 0:63ed631d8c3a | 260 | PinCfg.Portnum = 0; |
lynxeyed_atsu | 0:63ed631d8c3a | 261 | PINSEL_ConfigPin(&PinCfg); |
lynxeyed_atsu | 0:63ed631d8c3a | 262 | PinCfg.Pinnum = 3; |
lynxeyed_atsu | 0:63ed631d8c3a | 263 | PINSEL_ConfigPin(&PinCfg); |
lynxeyed_atsu | 0:63ed631d8c3a | 264 | #elif #if (USED_UART_DEBUG_PORT==1) |
lynxeyed_atsu | 0:63ed631d8c3a | 265 | /* |
lynxeyed_atsu | 0:63ed631d8c3a | 266 | * Initialize UART1 pin connect |
lynxeyed_atsu | 0:63ed631d8c3a | 267 | */ |
lynxeyed_atsu | 0:63ed631d8c3a | 268 | PinCfg.Funcnum = 1; |
lynxeyed_atsu | 0:63ed631d8c3a | 269 | PinCfg.OpenDrain = 0; |
lynxeyed_atsu | 0:63ed631d8c3a | 270 | PinCfg.Pinmode = 0; |
lynxeyed_atsu | 0:63ed631d8c3a | 271 | PinCfg.Pinnum = 15; |
lynxeyed_atsu | 0:63ed631d8c3a | 272 | PinCfg.Portnum = 0; |
lynxeyed_atsu | 0:63ed631d8c3a | 273 | PINSEL_ConfigPin(&PinCfg); |
lynxeyed_atsu | 0:63ed631d8c3a | 274 | PinCfg.Pinnum = 16; |
lynxeyed_atsu | 0:63ed631d8c3a | 275 | PINSEL_ConfigPin(&PinCfg); |
lynxeyed_atsu | 0:63ed631d8c3a | 276 | #endif |
lynxeyed_atsu | 0:63ed631d8c3a | 277 | |
lynxeyed_atsu | 0:63ed631d8c3a | 278 | /* Initialize UART Configuration parameter structure to default state: |
lynxeyed_atsu | 0:63ed631d8c3a | 279 | * Baudrate = 9600bps |
lynxeyed_atsu | 0:63ed631d8c3a | 280 | * 8 data bit |
lynxeyed_atsu | 0:63ed631d8c3a | 281 | * 1 Stop bit |
lynxeyed_atsu | 0:63ed631d8c3a | 282 | * None parity |
lynxeyed_atsu | 0:63ed631d8c3a | 283 | */ |
lynxeyed_atsu | 0:63ed631d8c3a | 284 | UART_ConfigStructInit(&UARTConfigStruct); |
lynxeyed_atsu | 0:63ed631d8c3a | 285 | // Re-configure baudrate to 115200bps |
lynxeyed_atsu | 0:63ed631d8c3a | 286 | UARTConfigStruct.Baud_rate = 9600;//115200; |
lynxeyed_atsu | 0:63ed631d8c3a | 287 | |
lynxeyed_atsu | 0:63ed631d8c3a | 288 | // Initialize DEBUG_UART_PORT peripheral with given to corresponding parameter |
lynxeyed_atsu | 0:63ed631d8c3a | 289 | UART_Init((LPC_UART_TypeDef *)DEBUG_UART_PORT, &UARTConfigStruct); |
lynxeyed_atsu | 0:63ed631d8c3a | 290 | |
lynxeyed_atsu | 0:63ed631d8c3a | 291 | // Enable UART Transmit |
lynxeyed_atsu | 0:63ed631d8c3a | 292 | UART_TxCmd((LPC_UART_TypeDef *)DEBUG_UART_PORT, ENABLE); |
lynxeyed_atsu | 0:63ed631d8c3a | 293 | |
lynxeyed_atsu | 0:63ed631d8c3a | 294 | _db_msg = UARTPuts; |
lynxeyed_atsu | 0:63ed631d8c3a | 295 | _db_msg_ = UARTPuts_; |
lynxeyed_atsu | 0:63ed631d8c3a | 296 | _db_char = UARTPutChar; |
lynxeyed_atsu | 0:63ed631d8c3a | 297 | _db_hex = UARTPutHex; |
lynxeyed_atsu | 0:63ed631d8c3a | 298 | _db_hex_16 = UARTPutHex16; |
lynxeyed_atsu | 0:63ed631d8c3a | 299 | _db_hex_32 = UARTPutHex32; |
lynxeyed_atsu | 0:63ed631d8c3a | 300 | _db_dec = UARTPutDec; |
lynxeyed_atsu | 0:63ed631d8c3a | 301 | _db_dec_16 = UARTPutDec16; |
lynxeyed_atsu | 0:63ed631d8c3a | 302 | _db_dec_32 = UARTPutDec32; |
lynxeyed_atsu | 0:63ed631d8c3a | 303 | _db_get_char = UARTGetChar; |
lynxeyed_atsu | 0:63ed631d8c3a | 304 | } |
lynxeyed_atsu | 0:63ed631d8c3a | 305 | #endif /*_DBGFWK */ |