📄 clock.c
字号:
//=================================================================//// clock.c//// Testcase for C library clock()////=================================================================//####COPYRIGHTBEGIN####// // ------------------------------------------- // The contents of this file are subject to the Red Hat eCos Public License // Version 1.1 (the "License"); you may not use this file except in // compliance with the License. You may obtain a copy of the License at // http://www.redhat.com/ // // Software distributed under the License is distributed on an "AS IS" // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the // License for the specific language governing rights and limitations under // the License. // // The Original Code is eCos - Embedded Configurable Operating System, // released September 30, 1998. // // The Initial Developer of the Original Code is Red Hat. // Portions created by Red Hat are // Copyright (C) 1998, 1999, 2000 Red Hat, Inc. // All Rights Reserved. // ------------------------------------------- // //####COPYRIGHTEND####//=================================================================//#####DESCRIPTIONBEGIN####//// Author(s): ctarpy// Contributors: ctarpy, jlarmour// Date: 1999-03-05// Description: Contains testcode for C library clock() function//////####DESCRIPTIONEND####// Declarations for test system://// TESTCASE_TYPE=CYG_TEST_MODULE// CONFIGURATION#include <pkgconf/libc.h> // Configuration header// INCLUDES#include <time.h>#include <cyg/infra/testcase.h>#include <sys/cstartup.h> // C library initialisation#define RUN_TEST 1// This test is bound to fail on Linux -- we don't have exclusive access// to the CPU.#if defined(CYGPKG_HAL_I386_LINUX)#undef RUN_TEST#define RUN_TEST 0#endif// HOW TO START TESTS#if RUN_TEST#include <cyg/hal/hal_cache.h>#include <cyg/hal/hal_intr.h># define START_TEST( test ) test(0)#else# define START_TEST( test ) CYG_EMPTY_STATEMENT#endif// CONSTANTS// This defines how many loops before we decide that// the clock doesnt work#define MAX_TIMEOUT 1000000// Percentage error before we declare fail: range 0 - 100#define TOLERANCE 40// FUNCTIONSexternC voidcyg_package_start( void ){ cyg_iso_c_start();} // cyg_package_start()#if RUN_TESTstatic intmy_abs(int i){ return (i < 0) ? -i : i;} // my_abs()static voidtest( CYG_ADDRWORD data ){ unsigned long ctr, ctr2, err; clock_t clock_init; clock_t clock_first=0, clock_second=0, clock_third=0; // First disable the caches - they may affect the timing loops // below - especially if tracing or assertions are enabled, causing // the elapsed time during the clock() call to vary. { register CYG_INTERRUPT_STATE oldints; HAL_DISABLE_INTERRUPTS(oldints); HAL_DCACHE_SYNC(); HAL_ICACHE_DISABLE(); HAL_DCACHE_DISABLE(); HAL_DCACHE_SYNC(); HAL_ICACHE_INVALIDATE_ALL(); HAL_DCACHE_INVALIDATE_ALL(); HAL_RESTORE_INTERRUPTS(oldints); } // This waits for a clock tick, to ensure that we are at the // start of a clock period. Then sit in a tight loop to get // the clock period. Repeat this, and make sure that it the // two timed periods are acceptably close. err = 101; clock_init = clock(); if (clock_init == (clock_t)-1) // unimplemented is just as valid { CYG_TEST_PASS_FINISH( "clock() returns -1, meaning unimplemented"); } // if for (ctr = 0; ctr<MAX_TIMEOUT; ctr++) { if ((clock_first=clock()) > clock_init) break; // Hit the next clock pulse } if (ctr < MAX_TIMEOUT) { // We hit a clock pulse, rather than a timeout // Now we are at the beginning of a pulse, so time until the // next one in order to get a measure of the length. for (ctr = 0; ctr<MAX_TIMEOUT; ctr++) { if ((clock_second=clock()) > clock_first) break; // Hit the next clock pulse } // for if (ctr < MAX_TIMEOUT) { // We hit a clock pulse, rather than a timeout. ctr contains // the number of loops/tick. Measure this again, and see if // the two results are acceptably close. for (ctr2 = 0; ctr2<MAX_TIMEOUT; ctr2++) { if ((clock_third=clock()) > clock_second) break; // Hit the next clock pulse } // for if (ctr2 < MAX_TIMEOUT) { err = (100 * my_abs(ctr-ctr2)) / ctr; } // if (ctr < MAX_TIMEOUT) else { CYG_TEST_FAIL_FINISH("No change in clock state!"); } // else (ctr < MAX_TIMEOUT) } // if (ctr < MAX_TIMEOUT) else { CYG_TEST_FAIL_FINISH("No change in clock state!"); } // else (ctr < MAX_TIMEOUT) } // if (ctr < MAX_TIMEOUT) else { CYG_TEST_FAIL_FINISH("No change in clock state!"); } // else (ctr < MAX_TIMEOUT) CYG_TEST_PASS_FAIL(err < TOLERANCE, "clock() stability"); CYG_TEST_FINISH("Finished tests from testcase " __FILE__ " for C library " "clock() function");} // test()#endifintmain(int argc, char *argv[]){ CYG_TEST_INIT(); CYG_TEST_INFO("Starting tests from testcase " __FILE__ " for C library " "clock() function"); START_TEST( test ); CYG_TEST_NA("Testing is not applicable to this configuration");} // main()// EOF clock.c
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -