blob: 8db9d25134fbc4636abc034c64c93ff585b55784 (
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
|
/* task1.c
*
* This set of three tasks do some simple task switching for about
* 15 seconds and then call a routine to "blow the stack".
*
* COPYRIGHT (c) 1989-2012.
* On-Line Applications Research Corporation (OAR).
*
* The license and distribution terms for this file may be
* found in the file LICENSE in this distribution or at
* http://www.rtems.com/license/LICENSE.
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <rtems.h>
#include <rtems/stackchk.h>
/* forward declarations to avoid warnings */
void b(void);
void blow_stack(void);
void b(void)
{
}
void blow_stack(void)
{
volatile uint32_t *low, *high;
unsigned char *area;
Thread_Control *executing;
b();
/*
* Destroy the first and last 16 bytes of our stack... Hope it
* does not cause problems :)
*/
executing = _Thread_Get_executing();
area = (unsigned char *)executing->Start.Initial_stack.area;
/* Look in the stack checker implementation for this magic offset */
low = (volatile uint32_t *) \
(area + sizeof(Heap_Block) - HEAP_BLOCK_HEADER_SIZE);
high = (volatile uint32_t *)
(area + executing->Start.Initial_stack.size - 16);
low[0] = 0x11111111;
low[1] = 0x22222222;
low[2] = 0x33333333;
low[3] = 0x44444444;
high[0] = 0x55555555;
high[1] = 0x66666666;
high[2] = 0x77777777;
high[3] = 0x88888888;
rtems_stack_checker_report_usage();
}
|