summaryrefslogtreecommitdiff
path: root/examples/example4/example4.c
blob: 78748f21c1aa57a1a7806a44bb88d4ebd9547400 (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
105
106
107
/*
 * SPDX license identifier: MPL-2.0
 *
 * Copyright (C) 2011-2015, BMW AG
 *
 * This file is part of GENIVI Project DLT - Diagnostic Log and Trace.
 *
 * This Source Code Form is subject to the terms of the
 * Mozilla Public License (MPL), v. 2.0.
 * If a copy of the MPL was not distributed with this file,
 * You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * For further information see http://www.genivi.org/.
 */

/*!
 * \author Alexander Wenzel <alexander.aw.wenzel@bmw.de>
 *
 * \copyright Copyright © 2011-2015 BMW AG. \n
 * License MPL-2.0: Mozilla Public License version 2.0 http://mozilla.org/MPL/2.0/.
 *
 * \file example4.c
 */


/*******************************************************************************
**                                                                            **
**  SRC-MODULE: example4.c                                                    **
**                                                                            **
**  TARGET    : linux                                                         **
**                                                                            **
**  PROJECT   : DLT                                                           **
**                                                                            **
**  AUTHOR    : Alexander Wenzel Alexander.AW.Wenzel@bmw.de                   **
**                                                                            **
**  PURPOSE   :                                                               **
**                                                                            **
**  REMARKS   :                                                               **
**                                                                            **
**  PLATFORM DEPENDANT [yes/no]: yes                                          **
**                                                                            **
**  TO BE CHANGED BY USER [yes/no]: no                                        **
**                                                                            **
*******************************************************************************/

#include <stdio.h>      /* for printf() and fprintf() */
#include <stdlib.h>     /* for atoi() and exit() */

#include <dlt.h>

DLT_DECLARE_CONTEXT(con_exa1);

int main()
{
    unsigned char buffer[256];
    int num;
    struct timespec ts;

    DLT_REGISTER_APP("EXA4", "Fourth Example");

    DLT_REGISTER_CONTEXT(con_exa1, "CON", "First context");

    for (num = 0; num < 256; num++)
        buffer[num] = num;

    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_STRING("DLT_RAW"));
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_RAW(buffer, 256));

    uint8_t uint8data = 0x2a;
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_STRING("DLT_UINT8"));
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_UINT8(uint8data));

    uint8_t hex8data = 0x1a;
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_STRING("DLT_HEX8"));
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_HEX8(hex8data));

    uint16_t hex16data = 0x1ad3;
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_STRING("DLT_HEX16"));
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_HEX16(hex16data));

    uint32_t hex32data = 0x1abcd3e4;
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_STRING("DLT_HEX32"));
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_HEX32(hex32data));

    uint64_t hex64data = 0x17b4ddcf34eabb2a;
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_STRING("DLT_HEX64"));
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_HEX64(hex64data));

    uint8_t bin8data = 0xe2;
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_STRING("DLT_BIN8"));
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_BIN8(bin8data));
    bin8data = 0x01;
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_STRING("DLT_BIN8"));
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_BIN8(bin8data));

    uint16_t bin16data = 0x1234;
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_STRING("DLT_BIN16"));
    DLT_LOG(con_exa1, DLT_LOG_INFO, DLT_BIN16(bin16data));

    ts.tv_sec = 0;
    ts.tv_nsec = 1000000;
    nanosleep(&ts, NULL);

    DLT_UNREGISTER_CONTEXT(con_exa1);

    DLT_UNREGISTER_APP();
}