| 
									
										
										
										
											2013-05-06 12:50:19 +07:00
										 |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |     @file     assertion.h | 
					
						
							|  |  |  |     @author   hathach (tinyusb.org) | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-06 12:50:19 +07:00
										 |  |  |     @section LICENSE | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Software License Agreement (BSD License) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Copyright (c) 2013, hathach (tinyusb.org) | 
					
						
							|  |  |  |     All rights reserved. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Redistribution and use in source and binary forms, with or without | 
					
						
							|  |  |  |     modification, are permitted provided that the following conditions are met: | 
					
						
							|  |  |  |     1. Redistributions of source code must retain the above copyright | 
					
						
							|  |  |  |     notice, this list of conditions and the following disclaimer. | 
					
						
							|  |  |  |     2. Redistributions in binary form must reproduce the above copyright | 
					
						
							|  |  |  |     notice, this list of conditions and the following disclaimer in the | 
					
						
							|  |  |  |     documentation and/or other materials provided with the distribution. | 
					
						
							|  |  |  |     3. Neither the name of the copyright holders nor the | 
					
						
							|  |  |  |     names of its contributors may be used to endorse or promote products | 
					
						
							|  |  |  |     derived from this software without specific prior written permission. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY | 
					
						
							|  |  |  |     EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | 
					
						
							|  |  |  |     WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | 
					
						
							|  |  |  |     DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY | 
					
						
							|  |  |  |     DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 
					
						
							|  |  |  |     INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | 
					
						
							|  |  |  |     LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION HOWEVER CAUSED AND | 
					
						
							|  |  |  |     ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
					
						
							|  |  |  |     INCLUDING NEGLIGENCE OR OTHERWISE ARISING IN ANY WAY OUT OF THE USE OF THIS | 
					
						
							|  |  |  |     SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     This file is part of the tinyusb stack. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** \file
 | 
					
						
							|  |  |  |  *  \brief TBD | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  \note TBD | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** \ingroup TBD
 | 
					
						
							|  |  |  |  *  \defgroup TBD | 
					
						
							|  |  |  |  *  \brief TBD | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  @{ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _TUSB_ASSERTION_H_
 | 
					
						
							|  |  |  | #define _TUSB_ASSERTION_H_
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "tusb_option.h"
 | 
					
						
							| 
									
										
										
										
											2013-04-09 02:13:18 +07:00
										 |  |  | #include "hal/hal.h" // TODO find a way to break hal dependency
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-19 16:11:11 +07:00
										 |  |  | #define VOID_RETURN
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-26 17:28:05 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Compile-time Assert
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-03-04 15:01:33 +07:00
										 |  |  | #ifdef __ICCARM__
 | 
					
						
							|  |  |  |   #define STATIC_ASSERT static_assert
 | 
					
						
							| 
									
										
										
										
											2013-02-26 17:28:05 +07:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2013-03-04 15:01:33 +07:00
										 |  |  |   #if defined __COUNTER__ && __COUNTER__ != __COUNTER__
 | 
					
						
							|  |  |  |     #define _ASSERT_COUNTER __COUNTER__
 | 
					
						
							|  |  |  |   #else
 | 
					
						
							|  |  |  |     #define _ASSERT_COUNTER __LINE__
 | 
					
						
							|  |  |  |   #endif
 | 
					
						
							| 
									
										
										
										
											2013-02-28 15:03:18 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-04 15:01:33 +07:00
										 |  |  |   #define STATIC_ASSERT(const_expr, message) enum { XSTRING_CONCAT_(static_assert_, _ASSERT_COUNTER) = 1/(!!(const_expr)) }
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-03-04 00:46:40 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  |   //#if ( defined CFG_PRINTF_UART || defined CFG_PRINTF_USBCDC || defined CFG_PRINTF_DEBUG )
 | 
					
						
							| 
									
										
										
										
											2013-02-28 15:03:18 +07:00
										 |  |  | #if TUSB_CFG_DEBUG == 3
 | 
					
						
							| 
									
										
										
										
											2013-04-25 15:43:33 +07:00
										 |  |  |   #define _PRINTF(...)	printf(__VA_ARGS__) // PRINTF
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | #else
 | 
					
						
							|  |  |  |   #define _PRINTF(...)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Assert Helper
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  | #ifndef _TEST_
 | 
					
						
							|  |  |  |   #define ASSERT_MESSAGE(format, ...)\
 | 
					
						
							|  |  |  |     _PRINTF("Assert at %s: %s: %d: " format "\n", __BASE_FILE__, __PRETTY_FUNCTION__, __LINE__, __VA_ARGS__) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   #define ASSERT_MESSAGE(format, ...)\
 | 
					
						
							|  |  |  |     _PRINTF("%d:note: Assert " format "\n", __LINE__, __VA_ARGS__) | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef _TEST_ASSERT_
 | 
					
						
							| 
									
										
										
										
											2013-03-22 17:08:51 +07:00
										 |  |  |   #define ASSERT_ERROR_HANDLER(x, para)  \
 | 
					
						
							| 
									
										
										
										
											2013-09-19 16:11:11 +07:00
										 |  |  |     return x | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2013-02-06 12:03:01 +07:00
										 |  |  |   #define ASSERT_ERROR_HANDLER(x, para)  Throw(x)
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-06 12:03:01 +07:00
										 |  |  | #define ASSERT_DEFINE_WITH_HANDLER(error_handler, handler_para, setup_statement, condition, error, format, ...) \
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  |   do{\ | 
					
						
							| 
									
										
										
										
											2013-01-13 20:00:01 +07:00
										 |  |  |     setup_statement;\ | 
					
						
							|  |  |  | 	  if (!(condition)) {\ | 
					
						
							| 
									
										
										
										
											2013-03-22 17:08:51 +07:00
										 |  |  | 	    if (hal_debugger_is_attached()){\ | 
					
						
							|  |  |  | 	      hal_debugger_breakpoint();\ | 
					
						
							|  |  |  | 	    }else{\ | 
					
						
							|  |  |  | 	      ASSERT_MESSAGE(format, __VA_ARGS__);\ | 
					
						
							|  |  |  | 	    }\ | 
					
						
							| 
									
										
										
										
											2013-02-06 12:03:01 +07:00
										 |  |  | 	    error_handler(error, handler_para);\ | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | 	  }\ | 
					
						
							|  |  |  | 	}while(0) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-06 12:03:01 +07:00
										 |  |  | #define ASSERT_DEFINE(...) ASSERT_DEFINE_WITH_HANDLER(ASSERT_ERROR_HANDLER, NULL, __VA_ARGS__)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | // tusb_error_t Status Assert TODO use ASSERT_DEFINE
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | #define ASSERT_STATUS_MESSAGE(sts, message) \
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  |     ASSERT_DEFINE(tusb_error_t status = (tusb_error_t)(sts),\ | 
					
						
							|  |  |  |                   TUSB_ERROR_NONE == status, status, "%s: %s", TUSB_ErrorStr[status], message) | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | #define ASSERT_STATUS(sts) \
 | 
					
						
							|  |  |  |     ASSERT_DEFINE(tusb_error_t status = (tusb_error_t)(sts),\ | 
					
						
							|  |  |  |                   TUSB_ERROR_NONE == status, status, "%s", TUSB_ErrorStr[status]) | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Logical Assert
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-01-14 00:41:23 +07:00
										 |  |  | #define ASSERT(...)                      ASSERT_TRUE(__VA_ARGS__)
 | 
					
						
							| 
									
										
										
										
											2013-01-18 14:39:42 +07:00
										 |  |  | #define ASSERT_TRUE(condition  , error)  ASSERT_DEFINE( , (condition), error, "%s", "evaluated to false")
 | 
					
						
							| 
									
										
										
										
											2013-01-14 00:41:23 +07:00
										 |  |  | #define ASSERT_FALSE(condition , error)  ASSERT_DEFINE( ,!(condition), error, "%s", "evaluated to true")
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | // Pointer Assert
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | #define ASSERT_PTR(...)                    ASSERT_PTR_NOT_NULL(__VA_ARGS__)
 | 
					
						
							|  |  |  | #define ASSERT_PTR_NOT_NULL(pointer, error) ASSERT_DEFINE( , NULL != (pointer), error, "%s", "pointer is NULL")
 | 
					
						
							|  |  |  | #define ASSERT_PTR_NULL(pointer, error)    ASSERT_DEFINE( , NULL == (pointer), error, "%s", "pointer is not NULL")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Integral Assert
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-01-14 00:41:23 +07:00
										 |  |  | #define ASSERT_XXX_EQUAL(type_format, expected, actual, error) \
 | 
					
						
							| 
									
										
										
										
											2013-01-13 20:09:51 +07:00
										 |  |  |     ASSERT_DEFINE(\ | 
					
						
							|  |  |  |                   uint32_t exp = (expected); uint32_t act = (actual),\ | 
					
						
							|  |  |  |                   exp==act,\ | 
					
						
							|  |  |  |                   error,\ | 
					
						
							| 
									
										
										
										
											2013-01-14 00:41:23 +07:00
										 |  |  |                   "expected " type_format ", actual " type_format, exp, act) | 
					
						
							| 
									
										
										
										
											2013-01-13 20:09:51 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-14 00:41:23 +07:00
										 |  |  | #define ASSERT_XXX_WITHIN(type_format, lower, upper, actual, error) \
 | 
					
						
							| 
									
										
										
										
											2013-01-13 20:09:51 +07:00
										 |  |  |     ASSERT_DEFINE(\ | 
					
						
							|  |  |  |                   uint32_t low = (lower); uint32_t up = (upper); uint32_t act = (actual),\ | 
					
						
							|  |  |  |                   (low <= act) && (act <= up),\ | 
					
						
							|  |  |  |                   error,\ | 
					
						
							| 
									
										
										
										
											2013-01-14 00:41:23 +07:00
										 |  |  |                   "expected within " type_format " - " type_format ", actual " type_format, low, up, act) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Integer Assert
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-01-14 00:41:23 +07:00
										 |  |  | #define ASSERT_INT(...)        ASSERT_INT_EQUAL(__VA_ARGS__)
 | 
					
						
							|  |  |  | #define ASSERT_INT_EQUAL(...)  ASSERT_XXX_EQUAL("%d", __VA_ARGS__)
 | 
					
						
							|  |  |  | #define ASSERT_INT_WITHIN(...) ASSERT_XXX_WITHIN("%d", __VA_ARGS__)
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-13 20:39:01 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Hex Assert
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-01-14 00:41:23 +07:00
										 |  |  | #define ASSERT_HEX(...)        ASSERT_HEX_EQUAL(__VA_ARGS__)
 | 
					
						
							|  |  |  | #define ASSERT_HEX_EQUAL(...)  ASSERT_XXX_EQUAL("0x%x", __VA_ARGS__)
 | 
					
						
							|  |  |  | #define ASSERT_HEX_WITHIN(...) ASSERT_XXX_WITHIN("0x%x", __VA_ARGS__)
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-18 14:39:42 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | // TODO Bin Assert
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-01-31 11:05:33 +07:00
										 |  |  | #define BIN8_PRINTF_PATTERN "%d%d%d%d%d%d%d%d"
 | 
					
						
							|  |  |  | #define BIN8_PRINTF_CONVERT(byte)  \
 | 
					
						
							|  |  |  |   ((byte) & 0x80 ? 1 : 0), \ | 
					
						
							|  |  |  |   ((byte) & 0x40 ? 1 : 0), \ | 
					
						
							|  |  |  |   ((byte) & 0x20 ? 1 : 0), \ | 
					
						
							|  |  |  |   ((byte) & 0x10 ? 1 : 0), \ | 
					
						
							|  |  |  |   ((byte) & 0x08 ? 1 : 0), \ | 
					
						
							|  |  |  |   ((byte) & 0x04 ? 1 : 0), \ | 
					
						
							|  |  |  |   ((byte) & 0x02 ? 1 : 0), \ | 
					
						
							|  |  |  |   ((byte) & 0x01 ? 1 : 0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ASSERT_BIN8(...)        ASSERT_BIN8_EQUAL(__VA_ARGS__)
 | 
					
						
							|  |  |  | #define ASSERT_BIN8_EQUAL(expected, actual, error)\
 | 
					
						
							|  |  |  |     ASSERT_DEFINE(\ | 
					
						
							|  |  |  |                   uint8_t exp = (expected); uint8_t act = (actual),\ | 
					
						
							|  |  |  |                   exp==act,\ | 
					
						
							|  |  |  |                   error,\ | 
					
						
							|  |  |  |                   "expected " BIN8_PRINTF_PATTERN ", actual " BIN8_PRINTF_PATTERN, BIN8_PRINTF_CONVERT(exp), BIN8_PRINTF_CONVERT(act) ) | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // TODO Bit Assert
 | 
					
						
							| 
									
										
										
										
											2013-01-18 14:39:42 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:27:17 +07:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* _TUSB_ASSERTION_H_ */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @} */ |