diff options
author | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2011-12-20 18:51:28 +0000 |
---|---|---|
committer | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2011-12-20 18:51:28 +0000 |
commit | 6100dc08a6a9f4592f324204bad26ba11239a030 (patch) | |
tree | 500cae05c312dc8209d06b88f6a954b2734fb9f6 /testhal/STM32F4xx | |
parent | cefffe9013b309de8661b5ce117a4472a2af6b92 (diff) | |
download | ChibiOS-6100dc08a6a9f4592f324204bad26ba11239a030.tar.gz ChibiOS-6100dc08a6a9f4592f324204bad26ba11239a030.tar.bz2 ChibiOS-6100dc08a6a9f4592f324204bad26ba11239a030.zip |
Cortex-M4 FPU support working.
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@3644 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'testhal/STM32F4xx')
-rw-r--r-- | testhal/STM32F4xx/IRQ_STORM_FPU/main.c | 55 |
1 files changed, 34 insertions, 21 deletions
diff --git a/testhal/STM32F4xx/IRQ_STORM_FPU/main.c b/testhal/STM32F4xx/IRQ_STORM_FPU/main.c index 73c98bf6f..a41c931e1 100644 --- a/testhal/STM32F4xx/IRQ_STORM_FPU/main.c +++ b/testhal/STM32F4xx/IRQ_STORM_FPU/main.c @@ -39,10 +39,6 @@ float ff2(float par1, float par2, float par3, float par4); #define ITERATIONS 100
#endif
-#ifndef NUM_THREADS
-#define NUM_THREADS 4
-#endif
-
/*===========================================================================*/
/* Test related code. */
/*===========================================================================*/
@@ -50,9 +46,9 @@ float ff2(float par1, float par2, float par3, float par4); static bool_t saturated;
/*
- * Test worker threads.
+ * Test worker thread.
*/
-static WORKING_AREA(waWorkerThread[NUM_THREADS], 128);
+static WORKING_AREA(waWorkerThread, 128);
static msg_t WorkerThread(void *arg) {
(void)arg;
@@ -72,10 +68,33 @@ static msg_t WorkerThread(void *arg) { }
/*
+ * Test periodic thread.
+ */
+static WORKING_AREA(waPeriodicThread, 128);
+static msg_t PeriodicThread(void *arg) {
+
+ (void)arg;
+
+ while(1) {
+ float f1, f2, f3, f4, f5;
+
+ f1 = ff1(4);
+ f2 = ff1(5);
+ f3 = ff1(6);
+ f5 = f1 + f2 + f3;
+ f4 = ff1(7);
+ f5 = ff2(f5, f4, f5, f4);
+ if (f5 != 484)
+ chSysHalt();
+ chThdSleepSeconds(1);
+ }
+}
+
+/*
* GPT2 callback.
*/
static void gpt2cb(GPTDriver *gptp) {
-/* float f1, f2, f3, f4, f5;
+ float f1, f2, f3, f4, f5;
(void)gptp;
@@ -86,14 +105,14 @@ static void gpt2cb(GPTDriver *gptp) { f4 = ff1(5);
f5 = ff2(f5, f4, f5, f4);
if (f5 != 196)
- chSysHalt();*/
+ chSysHalt();
}
/*
* GPT3 callback.
*/
static void gpt3cb(GPTDriver *gptp) {
-/* float f1, f2, f3, f4, f5;
+ float f1, f2, f3, f4, f5;
(void)gptp;
@@ -104,8 +123,7 @@ static void gpt3cb(GPTDriver *gptp) { f4 = ff1(4);
f5 = ff2(f5, f4, f5, f4);
if (f5 != 100)
- chSysHalt();*/
- volatile float f1 = ff1(1);
+ chSysHalt();
}
/*
@@ -185,14 +203,12 @@ int main(void) { gptStart(&GPTD3, &gpt3cfg);
/*
- * Initializes the mailboxes and creates the worker threads.
+ * Initializes the worker threads.
*/
-/* for (i = 0; i < NUM_THREADS; i++) {
- chThdCreateStatic(waWorkerThread[i], sizeof waWorkerThread[i],
- NORMALPRIO - 20, WorkerThread, (void *)i);
- }*/
- chThdCreateStatic(waWorkerThread[0], sizeof waWorkerThread[0],
- NORMALPRIO - 20, WorkerThread, (void *)0);
+ chThdCreateStatic(waWorkerThread, sizeof waWorkerThread,
+ NORMALPRIO - 20, WorkerThread, NULL);
+ chThdCreateStatic(waPeriodicThread, sizeof waPeriodicThread,
+ NORMALPRIO - 10, PeriodicThread, NULL);
/*
* Test procedure.
@@ -236,9 +252,6 @@ int main(void) { print("*** Randomize: ");
printn(RANDOMIZE);
println("");
- print("*** Threads: ");
- printn(NUM_THREADS);
- println("");
println("");
worst = 0;
|