| /* |
| * Copyright (c) 2010 The VP8 project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license and patent |
| * grant that can be found in the LICENSE file in the root of the source |
| * tree. All contributing project authors may be found in the AUTHORS |
| * file in the root of the source tree. |
| */ |
| |
| |
| /* This code is in the public domain. |
| ** Version: 1.1 Author: Walt Karas |
| */ |
| |
| /* Configure Heap Memory Manager for processor architecture, compiler, |
| ** and desired performance characteristics. This file is included |
| ** by heapmm.h, so these definitions can be used by code external to |
| ** HMM. You can change the default configuration, and/or create alternate |
| ** configuration(s). |
| */ |
| |
| /* To allow for multiple configurations of HMM to be used in the same |
| ** compilation unit, undefine all preprocessor symbols that will be |
| ** defined below. |
| */ |
| #undef HMM_ADDR_ALIGN_UNIT |
| #undef HMM_BLOCK_ALIGN_UNIT |
| #undef HMM_UNIQUE |
| #undef HMM_DESC_PARAM |
| #undef HMM_SYM_TO_STRING |
| #undef HMM_SYM_TO_STRING |
| #undef HMM_AUDIT_FAIL |
| |
| /* Turn X into a string after one macro expansion pass of X. This trick |
| ** works with both GCC and Visual C++. */ |
| #define HMM_SYM_TO_STRING(X) HMM_SYM_TO_STRING(X) |
| #define HMM_SYM_TO_STRING(X) #X |
| |
| #ifndef HMM_CNFG_NUM |
| |
| /* Default configuration. */ |
| |
| /* Use hmm_ prefix to avoid identifier conflicts. */ |
| #define HMM_UNIQUE(BASE) hmm_ ## BASE |
| |
| /* Number of bytes in an Address Alignment Unit (AAU). */ |
| //fwg |
| //#define HMM_ADDR_ALIGN_UNIT sizeof(int) |
| #define HMM_ADDR_ALIGN_UNIT 32 |
| |
| /* Number of AAUs in a Block Alignment Unit (BAU). */ |
| #define HMM_BLOCK_ALIGN_UNIT 1 |
| |
| /* Type of unsigned integer big enough to hold the size of a Block in AAUs. */ |
| typedef unsigned long HMM_UNIQUE(size_aau); |
| |
| /* Type of unsigned integer big enough to hold the size of a Block/Chunk |
| ** in BAUs. The high bit will be robbed. */ |
| typedef unsigned long HMM_UNIQUE(size_bau); |
| |
| void hmm_dflt_abort(const char *, const char *); |
| |
| /* Actions upon a self-audit failure. Must expand to a single complete |
| ** statement. If you remove the definition of this macro, no self-auditing |
| ** will be performed. */ |
| #define HMM_AUDIT_FAIL \ |
| hmm_dflt_abort(__FILE__, HMM_SYM_TO_STRING(__LINE__)); |
| |
| #elif HMM_CNFG_NUM == 0 |
| |
| /* Definitions for testing. */ |
| |
| #define HMM_UNIQUE(BASE) thmm_ ## BASE |
| |
| #define HMM_ADDR_ALIGN_UNIT sizeof(int) |
| |
| #define HMM_BLOCK_ALIGN_UNIT 3 |
| |
| typedef unsigned HMM_UNIQUE(size_aau); |
| |
| typedef unsigned short HMM_UNIQUE(size_bau); |
| |
| /* Under this test setup, a long jump is done if there is a self-audit |
| ** failure. |
| */ |
| |
| extern jmp_buf HMM_UNIQUE(jmp_buf); |
| extern const char *HMM_UNIQUE(fail_file); |
| extern unsigned HMM_UNIQUE(fail_line); |
| |
| #define HMM_AUDIT_FAIL \ |
| { HMM_UNIQUE(fail_file) = __FILE__; HMM_UNIQUE(fail_line) = __LINE__; \ |
| longjmp(HMM_UNIQUE(jmp_buf), 1); } |
| |
| #elif HMM_CNFG_NUM == 1 |
| |
| /* Put configuration 1 definitions here (if there is a configuration 1). */ |
| |
| #elif HMM_CNFG_NUM == 2 |
| |
| /* Put configuration 2 definitions here. */ |
| |
| #elif HMM_CNFG_NUM == 3 |
| |
| /* Put configuration 3 definitions here. */ |
| |
| #elif HMM_CNFG_NUM == 4 |
| |
| /* Put configuration 4 definitions here. */ |
| |
| #elif HMM_CNFG_NUM == 5 |
| |
| /* Put configuration 5 definitions here. */ |
| |
| #endif |