summaryrefslogtreecommitdiffstats
path: root/src/usr/pore/poreve/pore_model/include/pore_wrap.h
blob: e4f5f897f724db2c078de136b43c7d102ce8a80c (plain)
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/*  IBM_PROLOG_BEGIN_TAG
 *  This is an automatically generated prolog.
 *
 *  $Source: src/usr/pore/poreve/pore_model/include/pore_wrap.h $
 *
 *  IBM CONFIDENTIAL
 *
 *  COPYRIGHT International Business Machines Corp. 2011-2012
 *
 *  p1
 *
 *  Object Code Only (OCO) source materials
 *  Licensed Internal Code Source Materials
 *  IBM HostBoot Licensed Internal Code
 *
 *  The source code for this program is not published or other-
 *  wise divested of its trade secrets, irrespective of what has
 *  been deposited with the U.S. Copyright Office.
 *
 *  Origin: 30
 *
 *  IBM_PROLOG_END_TAG
 */
#ifndef __PORE_TRACE_H__
#define __PORE_TRACE_H__

/**
 * @file   pore_interface.h (for HostBoot environment)
 * @Author Thi Tran
 * @date   October, 2011
 *
 * @brief Trace functions for the Virtual Power-On-Reset Engine vPORe.
 * Since different users of this code use different ways of tracing,
 * It should be possible to replace the pore_model tracing with a
 * private version. In this file we use libc printfs to trace the flow
 * of the code if needed.
 *
 */

#include <stdint.h>
#include <stdio.h>
#include <stdarg.h>
#include <trace/interface.H>
#include <endian.h>

#ifdef __cplusplus
extern "C" {
#endif

extern trace_desc_t* g_poreDbgTd;
extern trace_desc_t* g_poreErrTd;

#ifndef htobe32
# if __BYTE_ORDER == __LITTLE_ENDIAN
#  define htobe32(x) __bswap_32 (x)
#  define htole32(x) (x)
#  define be32toh(x) __bswap_32 (x)
#  define le32toh(x) (x)

#  define htobe64(x) __bswap_64 (x)
#  define htole64(x) (x)
#  define be64toh(x) __bswap_64 (x)
#  define le64toh(x) (x)
# else
#  define htobe32(x) (x)
#  define htole32(x) __bswap_32 (x)
#  define be32toh(x) (x)
#  define le32toh(x) __bswap_32 (x)

#  define htobe64(x) (x)
#  define htole64(x) __bswap_64 (x)
#  define be64toh(x) (x)
#  define le64toh(x) __bswap_64 (x)
# endif
#endif

/** Using the following macros should help to adopt the code to
    different environments. */
#define pore_htobe64(x) htobe64(x)
#define pore_be64toh(x) be64toh(x)
#define pore_htobe32(x) htobe32(x)
#define pore_be32toh(x) be32toh(x)

// Debug trace
// '((void)p);' is to avoid unused variable error when compiling
#define printf(fmt, args...)        TRACFCOMP(g_poreDbgTd, fmt, ##args)
#define aprintf(fmt, args...)       TRACDCOMP(g_poreDbgTd, fmt, ##args)
#define eprintf(p, fmt, args...)    ((void)p); TRACDCOMP(g_poreDbgTd, fmt, ##args)
#define dprintf(p, fmt, args...)    ((void)p); TRACDCOMP(g_poreDbgTd, fmt, ##args)
#define bprintf(p, fmt, args...)    ((void)p); TRACDCOMP(g_poreDbgTd, fmt, ##args)
#define iprintf(p, fmt, args...)    ((void)p); TRACDCOMP(g_poreDbgTd, fmt, ##args)
#define pib_printf(p, fmt, args...) ((void)p); TRACDCOMP(g_poreDbgTd, fmt, ##args)
#define mem_printf(p, fmt, args...) ((void)p); TRACDCOMP(g_poreDbgTd, fmt, ##args)

// Diagnostic aid
#define BUG() \
    TRACFCOMP(g_poreErrTd, ">>> Bug trapped at %s:%d", \
    __FILE__, __LINE__ )

#ifdef __cplusplus
}
#endif

#endif /* __PORE_TRACE_H__ */
OpenPOWER on IntegriCloud