📄 clock.c
字号:
//=================================================================//// clock.c//// Testcase for C library clock()////=================================================================//####COPYRIGHTBEGIN####//// -------------------------------------------// The contents of this file are subject to the Cygnus eCos Public License// Version 1.0 (the "License"); you may not use this file except in// compliance with the License. You may obtain a copy of the License at// http://sourceware.cygnus.com/ecos// // 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 Cygnus Operating System, released// September 30, 1998.// // The Initial Developer of the Original Code is Cygnus. Portions created// by Cygnus are Copyright (C) 1998,1999 Cygnus Solutions. 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># 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 instruction cache - it may affect the timing loops // below HAL_ICACHE_DISABLE(); // 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 + -