Skip to content

Commit 7e81c6a

Browse files
committed
Add FreeRTOS software and first task to test sobel
1 parent 7197c93 commit 7e81c6a

File tree

21 files changed

+18937
-0
lines changed

21 files changed

+18937
-0
lines changed

modules/VirtualPrototype/FreeRTOS/FreeRTOS.h

Lines changed: 1278 additions & 0 deletions
Large diffs are not rendered by default.
Lines changed: 147 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,147 @@
1+
/*
2+
FreeRTOS V8.2.3 - Copyright (C) 2015 Real Time Engineers Ltd.
3+
All rights reserved
4+
5+
VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.
6+
7+
This file is part of the FreeRTOS distribution.
8+
9+
FreeRTOS is free software; you can redistribute it and/or modify it under
10+
the terms of the GNU General Public License (version 2) as published by the
11+
Free Software Foundation >>>> AND MODIFIED BY <<<< the FreeRTOS exception.
12+
13+
***************************************************************************
14+
>>! NOTE: The modification to the GPL is included to allow you to !<<
15+
>>! distribute a combined work that includes FreeRTOS without being !<<
16+
>>! obliged to provide the source code for proprietary components !<<
17+
>>! outside of the FreeRTOS kernel. !<<
18+
***************************************************************************
19+
20+
FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY
21+
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
22+
FOR A PARTICULAR PURPOSE. Full license text is available on the following
23+
link: http://www.freertos.org/a00114.html
24+
25+
***************************************************************************
26+
* *
27+
* FreeRTOS provides completely free yet professionally developed, *
28+
* robust, strictly quality controlled, supported, and cross *
29+
* platform software that is more than just the market leader, it *
30+
* is the industry's de facto standard. *
31+
* *
32+
* Help yourself get started quickly while simultaneously helping *
33+
* to support the FreeRTOS project by purchasing a FreeRTOS *
34+
* tutorial book, reference manual, or both: *
35+
* http://www.FreeRTOS.org/Documentation *
36+
* *
37+
***************************************************************************
38+
39+
http://www.FreeRTOS.org/FAQHelp.html - Having a problem? Start by reading
40+
the FAQ page "My application does not run, what could be wrong?". Have you
41+
defined configASSERT()?
42+
43+
http://www.FreeRTOS.org/support - In return for receiving this top quality
44+
embedded software for free we request you assist our global community by
45+
participating in the support forum.
46+
47+
http://www.FreeRTOS.org/training - Investing in training allows your team to
48+
be as productive as possible as early as possible. Now you can receive
49+
FreeRTOS training directly from Richard Barry, CEO of Real Time Engineers
50+
Ltd, and the world's leading authority on the world's leading RTOS.
51+
52+
http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,
53+
including FreeRTOS+Trace - an indispensable productivity tool, a DOS
54+
compatible FAT file system, and our tiny thread aware UDP/IP stack.
55+
56+
http://www.FreeRTOS.org/labs - Where new FreeRTOS products go to incubate.
57+
Come and try FreeRTOS+TCP, our new open source TCP/IP stack for FreeRTOS.
58+
59+
http://www.OpenRTOS.com - Real Time Engineers ltd. license FreeRTOS to High
60+
Integrity Systems ltd. to sell under the OpenRTOS brand. Low cost OpenRTOS
61+
licenses offer ticketed support, indemnification and commercial middleware.
62+
63+
http://www.SafeRTOS.com - High Integrity Systems also provide a safety
64+
engineered and independently SIL3 certified version for use in safety and
65+
mission critical applications that require provable dependability.
66+
67+
1 tab == 4 spaces!
68+
*/
69+
70+
71+
#ifndef FREERTOS_CONFIG_H
72+
#define FREERTOS_CONFIG_H
73+
74+
75+
/*-----------------------------------------------------------
76+
* Application specific definitions.
77+
*
78+
* These definitions should be adjusted for your particular hardware and
79+
* application requirements.
80+
*
81+
* THESE PARAMETERS ARE DESCRIBED WITHIN THE 'CONFIGURATION' SECTION OF THE
82+
* FreeRTOS API DOCUMENTATION AVAILABLE ON THE FreeRTOS.org WEB SITE.
83+
*
84+
* See http://www.freertos.org/a00110.html.
85+
*----------------------------------------------------------*/
86+
87+
#define configCLINT_BASE_ADDRESS 0 /* There is no CLINT so the base address must be set to 0. */
88+
#define configUSE_PREEMPTION 1
89+
#define configUSE_IDLE_HOOK 0
90+
#define configUSE_TICK_HOOK 0
91+
#define configCPU_CLOCK_HZ BOARD_BOOTCLOCKRUN_CORE_CLOCK
92+
#define configTICK_RATE_HZ ( ( TickType_t ) 1000 )
93+
#define configMAX_PRIORITIES ( 5 )
94+
#define configMINIMAL_STACK_SIZE ( ( unsigned short ) 500 ) /* Can be as low as 60 but some of the demo tasks that use this constant require it to be higher. */
95+
#define configTOTAL_HEAP_SIZE ( ( size_t ) ( 100 * 1024 ) )
96+
#define configMAX_TASK_NAME_LEN ( 16 )
97+
#define configUSE_TRACE_FACILITY 0
98+
#define configUSE_16_BIT_TICKS 0
99+
#define configIDLE_SHOULD_YIELD 0
100+
#define configUSE_MUTEXES 1
101+
#define configQUEUE_REGISTRY_SIZE 8
102+
#define configCHECK_FOR_STACK_OVERFLOW 2
103+
#define configUSE_RECURSIVE_MUTEXES 1
104+
#define configUSE_MALLOC_FAILED_HOOK 1
105+
#define configUSE_APPLICATION_TASK_TAG 0
106+
#define configUSE_COUNTING_SEMAPHORES 1
107+
#define configGENERATE_RUN_TIME_STATS 0
108+
109+
/* Co-routine definitions. */
110+
#define configUSE_CO_ROUTINES 0
111+
#define configMAX_CO_ROUTINE_PRIORITIES ( 2 )
112+
113+
/* Software timer definitions. */
114+
#define configUSE_TIMERS 0
115+
#define configTIMER_TASK_PRIORITY ( configMAX_PRIORITIES - 1 )
116+
#define configTIMER_QUEUE_LENGTH 4
117+
#define configTIMER_TASK_STACK_DEPTH ( configMINIMAL_STACK_SIZE )
118+
119+
/* Task priorities. Allow these to be overridden. */
120+
#ifndef uartPRIMARY_PRIORITY
121+
#define uartPRIMARY_PRIORITY ( configMAX_PRIORITIES - 3 )
122+
#endif
123+
124+
/* Set the following definitions to 1 to include the API function, or zero
125+
to exclude the API function. */
126+
#define INCLUDE_vTaskPrioritySet 1
127+
#define INCLUDE_uxTaskPriorityGet 1
128+
#define INCLUDE_vTaskDelete 1
129+
#define INCLUDE_vTaskCleanUpResources 1
130+
#define INCLUDE_vTaskSuspend 1
131+
#define INCLUDE_vTaskDelayUntil 1
132+
#define INCLUDE_vTaskDelay 1
133+
#define INCLUDE_eTaskGetState 1
134+
#define INCLUDE_xTimerPendFunctionCall 0
135+
#define INCLUDE_xTaskAbortDelay 1
136+
#define INCLUDE_xTaskGetHandle 1
137+
#define INCLUDE_xSemaphoreGetMutexHolder 1
138+
139+
/* Normal assert() semantics without relying on the provision of an assert.h
140+
header file. */
141+
#define configASSERT( x ) if( ( x ) == 0 ) { taskDISABLE_INTERRUPTS(); __asm volatile( "ebreak" ); for( ;; ); }
142+
143+
#define configUSE_PORT_OPTIMISED_TASK_SELECTION 0
144+
#define configKERNEL_INTERRUPT_PRIORITY 7
145+
146+
147+
#endif /* FREERTOS_CONFIG_H */
Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,61 @@
1+
TARGET = freertos
2+
3+
TARGET_ARCH = riscv32
4+
5+
CC = riscv32-unknown-elf-gcc
6+
7+
# compiling flags here
8+
CFLAGS = -Wall -I. -O0 -static -march=rv32gc -mabi=ilp32 --specs=nosys.specs
9+
CFLAGS+=-std=c++17
10+
11+
LINKER = riscv32-unknown-elf-gcc
12+
# linking flags here
13+
LDFLAGS = -I. -static
14+
LIBS = $(EXTRA_LIBS)
15+
16+
CFLAGS += -DUSING_RISCV_TLM_TB_EN
17+
LDFLAGS += -DUSING_RISCV_TLM_TB_EN
18+
19+
# change these to proper directories where each file should be
20+
SRCDIR = ./
21+
OBJDIR = .
22+
BINDIR = ./
23+
INCDIR = -I. -I../../edge-detector/include -I../include
24+
LIBDIR = -L.
25+
26+
27+
SOURCES := $(wildcard $(SRCDIR)/*.c)
28+
INCLUDES := $(wildcard $(INCDIR)/*.h)
29+
OBJECTS := $(SOURCES:$(SRCDIR)/%.c=$(OBJDIR)/%.o)
30+
31+
SOURCES_ASM := $(wildcard $(SRCDIR)/*.S)
32+
OBJECTS_ASM := $(SOURCES_ASM:$(SRCDIR)/%.S=$(OBJDIR)/%.o)
33+
34+
rm = rm -f
35+
36+
37+
$(BINDIR)/$(TARGET): $(OBJECTS) $(OBJECTS_ASM)
38+
$(LINKER) $(CFLAGS) $(LDFLAGS) $(LIBS) $(LIBDIR) $(OBJECTS) $(OBJECTS_ASM) -lm -o $@
39+
riscv32-unknown-elf-objdump -d $@ > dump
40+
riscv32-unknown-elf-objcopy -Oihex $@ $(TARGET).hex
41+
@echo "Linking complete!"
42+
43+
$(OBJECTS): $(OBJDIR)/%.o : $(SRCDIR)/%.c
44+
@echo "Compiling "$<" ..."
45+
$(CC) $(CFLAGS) $(INCDIR) -c $< -o $@
46+
@echo "Done!"
47+
48+
$(OBJECTS_ASM): $(OBJDIR)/%.o: $(SRCDIR)/%.S
49+
@echo "Assembling "$<" ..."
50+
$(CC) $(CFLAGS) $(INCDIR) -c $< -o $@
51+
@echo "Done!"
52+
53+
.PHONY: clean
54+
clean:
55+
@$(rm) $(TARGET) $(OBJECTS) $(OBJECTS_ASM) *.hex dump
56+
@echo "Cleanup complete!"
57+
58+
.PHONY: remove
59+
remove: clean
60+
@$(rm) $(BINDIR)/$(TARGET)
61+
@echo "Executable removed!"

0 commit comments

Comments
 (0)