📄 clock.cxx
字号:
//===========================================================================//// clock.cxx//// ISO C date and time implementation for clock()////===========================================================================//####ECOSGPLCOPYRIGHTBEGIN####// -------------------------------------------// This file is part of eCos, the Embedded Configurable Operating System.// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.//// eCos is free software; you can redistribute it and/or modify it under// the terms of the GNU General Public License as published by the Free// Software Foundation; either version 2 or (at your option) any later version.//// eCos is distributed in the hope that it will be useful, but WITHOUT ANY// WARRANTY; without even the implied warranty of MERCHANTABILITY or// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License// for more details.//// You should have received a copy of the GNU General Public License along// with eCos; if not, write to the Free Software Foundation, Inc.,// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.//// As a special exception, if other files instantiate templates or use macros// or inline functions from this file, or you compile this file and link it// with other works to produce a work based on this file, this file does not// by itself cause the resulting work to be covered by the GNU General Public// License. However the source code for this file must still be made available// in accordance with section (3) of the GNU General Public License.//// This exception does not invalidate any other reasons why a work based on// this file might be covered by the GNU General Public License.//// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.// at http://sources.redhat.com/ecos/ecos-license/// -------------------------------------------//####ECOSGPLCOPYRIGHTEND####//===========================================================================//#####DESCRIPTIONBEGIN####//// Author(s): jlarmour// Contributors: jlarmour// Date: 1999-03-05// Purpose: Provides an implementation of the ISO C function clock()// from ISO C section 7.12.2.1// Description: This file uses the kernel real time clock to determine// the complete running time of the system - since we only// have one task, even though there are perhaps multiple threads// that is still the running time of the "program"// Usage: ////####DESCRIPTIONEND####////===========================================================================// CONFIGURATION#include <pkgconf/libc_time.h> // Configuration header#ifdef CYGSEM_LIBC_TIME_CLOCK_WORKING# include <pkgconf/kernel.h> // Kernel config header#endif// INCLUDES#include <cyg/infra/cyg_type.h> // Common type definitions and support#include <cyg/infra/cyg_ass.h> // Assertion infrastructure#include <cyg/infra/cyg_trac.h> // Tracing infrastructure#include <time.h> // Header for all time-related functions#ifdef CYGSEM_LIBC_TIME_CLOCK_WORKING# include <cyg/kernel/clock.hxx> // Kernel clock definitions# include <cyg/kernel/clock.inl> // Kernel clock inline functions#endif// TRACE# if defined(CYGDBG_USE_TRACING) && defined(CYGNUM_LIBC_TIME_CLOCK_TRACE_LEVEL)static int clock_trace = CYGNUM_LIBC_TIME_CLOCK_TRACE_LEVEL;# define TL1 (0 < clock_trace)# else# define TL1 (0)# endif// FUNCTIONSexternC clock_tclock( void ){ CYG_REPORT_FUNCNAMETYPE( "clock", "returning clock tick %d" ); CYG_REPORT_FUNCARGVOID();#ifdef CYGSEM_LIBC_TIME_CLOCK_WORKING cyg_tick_count curr_clock; // kernel clock value Cyg_Clock::cyg_resolution resolution; // kernel clock resolution clock_t clocks; unsigned long long temp; CYG_TRACE0( TL1, "getting clock resolution" ); // get the resolution resolution = Cyg_Clock::real_time_clock->get_resolution(); CYG_TRACE2( TL1, "got resolution dividend %d divisor %d. Getting " "clock value", resolution.dividend, resolution.divisor ); // get the value curr_clock = Cyg_Clock::real_time_clock->current_value(); CYG_TRACE1( TL1, "got clock value %d", curr_clock ); // scale the value so that clock()/CLOCKS_PER_SEC works // We use an unsigned long long to avoid overflow as the dividend // and divisors tend to be huge temp = (1000000000 / CLOCKS_PER_SEC); temp *= resolution.divisor; temp = (unsigned long long)curr_clock * resolution.dividend / temp; clocks = (clock_t)temp; CYG_REPORT_RETVAL( clocks ); return clocks;#else // i.e. ifndef CYGSEM_LIBC_TIME_CLOCK_WORKING CYG_REPORT_RETVAL( -1 ); return (clock_t) -1;#endif} // clock()// EOF clock.cxx
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -