summaryrefslogtreecommitdiffstats
path: root/sbe/sample/sample_main.C
blob: fae103559f5710d73f149c5639f5d14f7215726d (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
//-----------------------------------------------------------------------------
// *! (C) Copyright International Business Machines Corp. 2014
// *! All Rights Reserved -- Property of IBM
// *! *** IBM Confidential ***
//-----------------------------------------------------------------------------

/// \file sample_main.c
/// \brief Sample program that creates and starts a thread
///
/// This file demonstrates how to create a thread and run it.  It also provides
/// an example of how to add traces to the code.
extern "C" {
#include "pk.h"
#include "pk_trace.h"
#include "pk_scom.h"
#include "pk_trace_wrap.h"
}
#define KERNEL_STACK_SIZE   256
#define MAIN_THREAD_STACK_SIZE  256



uint8_t     G_kernel_stack[KERNEL_STACK_SIZE];
uint8_t     G_main_thread_stack[MAIN_THREAD_STACK_SIZE];
PkThread    G_main_thread;

class Thetest {

 public:
    int i;

};

// A simple thread that just increments a local variable and sleeps
void main_thread(void* arg)
{
    //Thetest mytest;

    //mytest.i = 0;

    //std::cout << "sdfds" << std::endl;

    uint16_t a = 0;
 
    pk_trace_wrap("sdfsdf");
    //PK_TRACE("thread started");


    while(1)
    {
        // PK_TRACE can take up to 4 parameters
        // (not including the format string)
        //PK_TRACE("thread seconds = %d", a);
        pk_sleep(PK_SECONDS(1));

        uint64_t i_data = 0x0110;

        putscom(0x33333, 0x11111, i_data);

        getscom(0x33333, 0x11111, &i_data);

        a++;
    }
}


// The main function is called by the boot code (after initializing some
// registers)
int main(int argc, char **argv)
{
    // initializes kernel data (stack, threads, timebase, timers, etc.)
    pk_initialize((PkAddress)G_kernel_stack,
                  KERNEL_STACK_SIZE,
                  0,
                  500000000);

    //PK_TRACE("Kernel init completed");

    //Initialize the thread control block for G_main_thread
    pk_thread_create(&G_main_thread,
                      (PkThreadRoutine)main_thread,
                      (void*)NULL,
                      (PkAddress)G_main_thread_stack,
                      (size_t)MAIN_THREAD_STACK_SIZE,
                      (PkThreadPriority)1);

    //PK_TRACE_BIN("G_main_thread", &G_main_thread, sizeof(G_main_thread));

    //Make G_main_thread runnable
    pk_thread_resume(&G_main_thread);

    //PK_TRACE("Starting thread(s)");

    // Start running the highest priority thread.
    // This function never returns
    pk_start_threads();
    
    return 0;
}
OpenPOWER on IntegriCloud