summaryrefslogtreecommitdiff
path: root/software/mpu/src/kernel.c
blob: f5d04ea1c781fbfd3a7b5fea76220ae2dbca8544 (plain) (blame)
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
108
109
110
111
112
113
114
115
116
117
/*
 * kernel.c
 *
 *  Created on: 13.09.2011
 *      Author: Roland
 */
#include "Types.h"
#include "FreeRTOS.h"
#include "queue.h"
#include "uart.h"

#define	kernel_TASK_PRIORITY		    ( tskIDLE_PRIORITY + 5 )
#define kernel_TASK_STACK_SIZE			( ( unsigned short ) 64 )

void UARTSend(uint8_t *BufferPtr, uint32_t Length);

/* Globals */
#define BUFSIZE		0x40	// fixme: ...is sdefined in hart.h
static Task_Param_t kernel_Param;
extern volatile uint32_t UARTCount;
extern volatile uint8_t UARTBuffer[BUFSIZE];

/*
 * Wake up other tasks, send them messages telling what to do,
 * wait for them to have processed the commands or not, maybe
 * put them to sleep again, ...
 * */
static void kernel_Process_Task(void *Param)
{
	Message_t RcvMsg;
	Message_t SndMsg;
	portTickType tick;
	portCHAR chBufCam[10] = "Seas Cam!";
	portCHAR chBufLSen[10] = "Seas LSe!";
	portCHAR l = 'l';

	if(NULL == kernel_Param.QueueHandles.hxq_Kernel)
	{
		return;
	}

	tick = xTaskGetTickCount();
	while(1)
	{
		vTaskDelayUntil(&tick, MS(3));

		if( xQueueReceive( kernel_Param.QueueHandles.hxq_Kernel, &RcvMsg, MS(5)))
		{
			/*
			 * switch Msg.Sender and act accordingly.
			 */
			switch (RcvMsg.Sender)
			{
			case Sender_Camera:
			{
				SndMsg.Sender = Sender_Kernel;
				SndMsg.pData = chBufCam;
				xQueueSend(kernel_Param.QueueHandles.hxq_Camera, &SndMsg, MS(10));
				break;
			}

			case Sender_LightSens:
			{
				SndMsg.Sender = Sender_Kernel;
				SndMsg.pData = chBufLSen;
				for(l = 0; l < 8; l ++)
				{
					UARTBuffer[l*4 +0] = 48+(((uint8_t *)(RcvMsg.pData))[l])%1000 / 100;
					UARTBuffer[l*4 +1] = 48+(((uint8_t *)(RcvMsg.pData))[l])%100 / 10;
					UARTBuffer[l*4 +2] = 48+(((uint8_t *)(RcvMsg.pData))[l])%10;
					UARTBuffer[l*4 +3] = ' ';
				}
				UARTCount = 34;
				UARTBuffer[32] = '\r';
				UARTBuffer[33] = '\n';
				UARTSend( (uint8_t *)UARTBuffer, UARTCount );
//				UARTSend( (uint8_t *)(RcvMsg.pData), 10 );
//				xQueueSend(kernel_Param.QueueHandles.hxq_LightSens, &SndMsg, MS(10));
				break;
			}
			case Sender_UART:
			{
				if (UARTBuffer[UARTCount-1] != 'i')
					break;
				if ( UARTCount != 0 )
				{
				  LPC_UART->IER = IER_THRE | IER_RLS;			/* Disable RBR */
				  UARTSend( (uint8_t *)UARTBuffer, UARTCount );
				  UARTCount = 0;
				  LPC_UART->IER = IER_THRE | IER_RLS | IER_RBR;	/* Re-enable RBR */

				  l = 'r';
				  SndMsg.pData = &l;

				  xQueueSend(kernel_Param.QueueHandles.hxq_LightSens, &SndMsg, MS(10));
				}
				break;
			}
			default: {;}
			}
		}
	}
}

Status_t kernel_Init_Kernel(QH_t  hxQueues)
{
portBASE_TYPE xResult;

	xResult = xTaskCreate( kernel_Process_Task, (signed char *) "Kernel",
						   kernel_TASK_STACK_SIZE, &kernel_Param,
						   kernel_TASK_PRIORITY, &(kernel_Param.hxTask_Self) );

	kernel_Param.QueueHandles = hxQueues;

	/*TODO: check for success and pass it over to caller. */
	return STATUS_OK;
}