diff options
| author | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2008-07-02 14:01:18 +0000 | 
|---|---|---|
| committer | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2008-07-02 14:01:18 +0000 | 
| commit | d7443aaab6d740ef3175530c45c49f2a49b9c9d5 (patch) | |
| tree | 05c29894ee11a37faa338d1e2424b355017afa74 /test | |
| parent | 5f4dbf9ca9ba32bfeefa3dbab412867dc63f0892 (diff) | |
| download | ChibiOS-d7443aaab6d740ef3175530c45c49f2a49b9c9d5.tar.gz ChibiOS-d7443aaab6d740ef3175530c45c49f2a49b9c9d5.tar.bz2 ChibiOS-d7443aaab6d740ef3175530c45c49f2a49b9c9d5.zip | |
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@329 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'test')
| -rw-r--r-- | test/testbmk.c | 21 | 
1 files changed, 11 insertions, 10 deletions
| diff --git a/test/testbmk.c b/test/testbmk.c index b0f44f315..18a62bf00 100644 --- a/test/testbmk.c +++ b/test/testbmk.c @@ -27,13 +27,13 @@ static unsigned int msg_loop_test(Thread *tp) {    uint32_t n = 0;
    test_wait_tick();
    test_start_timer(1000);
 -  while (!test_timer_done) {
 +  do {
      (void)chMsgSend(tp, 0);
      n++;
  #if defined(WIN32)
      ChkIntSources();
  #endif
 -  }
 +  } while (!test_timer_done);
    return n;
  }
 @@ -122,7 +122,7 @@ static void bmk3_teardown(void) {  static msg_t thread2(void *p) {
 -  return 0;
 +  return (msg_t)p;
  }
  static void bmk3_execute(void) {
 @@ -153,7 +153,7 @@ const struct testcase testbmk3 = {  static char *bmk4_gettest(void) {
 -  return "Benchmark, threads creation/termination";
 +  return "Benchmark, threads creation/termination, worst case";
  }
  static void bmk4_setup(void) {
 @@ -165,16 +165,17 @@ static void bmk4_teardown(void) {  static void bmk4_execute(void) {
    uint32_t n = 0;
 +  void *wap = wa[0];
 +  tprio_t prio = chThdGetPriority() - 1;
    test_wait_tick();
    test_start_timer(1000);
 -  while (!test_timer_done) {
 -    threads[0] = chThdCreate(chThdGetPriority()-1, 0, wa[0], STKSIZE, thread2, NULL);
 -    chThdWait(threads[0]);
 +  do {
 +    chThdWait(chThdCreate(prio, 0, wap, STKSIZE, thread2, NULL));
      n++;
  #if defined(WIN32)
      ChkIntSources();
  #endif
 -  }
 +  } while (!test_timer_done);
    test_print("--- Score : ");
    test_printn(n);
    test_println(" threads/S");
 @@ -206,7 +207,7 @@ static void bmk5_execute(void) {    uint32_t n = 0;
    test_wait_tick();
    test_start_timer(1000);
 -  while (!test_timer_done) {
 +  do {
      chIQPutI(&iq, 0);
      chIQPutI(&iq, 1);
      chIQPutI(&iq, 2);
 @@ -219,7 +220,7 @@ static void bmk5_execute(void) {  #if defined(WIN32)
      ChkIntSources();
  #endif
 -  }
 +  } while (!test_timer_done);
    test_print("--- Score : ");
    test_printn(n * 4);
    test_println(" bytes/S");
 | 
