/* timing.h -- optional support for run-time time stamp collection
* Copyright (C) 2009 SEIKO EPSON CORPORATION
*
* License: GPLv2+|iscan
* Authors: AVASYS CORPORATION
*
* This file is part of the SANE backend distributed with Image Scan!
*
* Image Scan!'s SANE backend 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 of the License or at your option any later version.
*
* This program 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 ought to have received a copy of the GNU General Public License
* along with this package. If not, see .
*
*
* Linking Image Scan!'s SANE backend statically or dynamically with
* other modules is making a combined work based on this SANE backend.
* Thus, the terms and conditions of the GNU General Public License
* cover the whole combination.
*
* As a special exception, the copyright holders of Image Scan!'s SANE
* backend give you permission to link Image Scan!'s SANE backend with
* SANE frontends that communicate with Image Scan!'s SANE backend
* solely through the SANE Application Programming Interface,
* regardless of the license terms of these SANE frontends, and to
* copy and distribute the resulting combined work under terms of your
* choice, provided that every copy of the combined work is
* accompanied by a complete copy of the source code of Image Scan!'s
* SANE backend (the version of Image Scan!'s SANE backend used to
* produce the combined work), being distributed under the terms of
* the GNU General Public License plus this exception. An independent
* module is a module which is not derived from or based on Image
* Scan!'s SANE backend.
*
* As a special exception, the copyright holders of Image Scan!'s SANE
* backend give you permission to link Image Scan!'s SANE backend with
* independent modules that communicate with Image Scan!'s SANE
* backend solely through the "Interpreter" interface, regardless of
* the license terms of these independent modules, and to copy and
* distribute the resulting combined work under terms of your choice,
* provided that every copy of the combined work is accompanied by a
* complete copy of the source code of Image Scan!'s SANE backend (the
* version of Image Scan!'s SANE backend used to produce the combined
* work), being distributed under the terms of the GNU General Public
* License plus this exception. An independent module is a module
* which is not derived from or based on Image Scan!'s SANE backend.
*
* Note that people who make modified versions of Image Scan!'s SANE
* backend are not obligated to grant special exceptions for their
* modified versions; it is their choice whether to do so. The GNU
* General Public License gives permission to release a modified
* version without this exception; this exception also makes it
* possible to release a modified version which carries forward this
* exception.
*/
#ifndef timing_h_included
#define timing_h_included
#ifdef HAVE_CONFIG_H
#include
#endif
#include
#ifndef ENABLE_TIMING
#define ENABLE_TIMING 0
#endif
#define TIME_PASS_MAX 100
extern size_t time_pass_count;
#if !ENABLE_TIMING /* turn API calls into no-ops */
#define time_clear() do {} while (0)
#define time_stamp(interval,end) do {} while (0)
#define time_stats(count) do {} while (0)
#else /* do something useful */
#include
#include "defines.h"
struct time_stamp_
{
bool is_valid;
struct timespec t;
};
struct time_interval_
{
struct time_stamp_ start;
struct time_stamp_ stop;
struct time_stamp_ span;
};
extern struct time_interval_ time_scan;
extern struct time_interval_ time_pass[TIME_PASS_MAX];
#define time_stamp(interval,end) \
do { \
interval.end.is_valid = (0 == clock_gettime (CLOCK_MONOTONIC, \
&(interval.end.t))); \
} while (0)
void time_clear (void);
void time_stats (size_t count);
#endif /* ENABLE_TIMING */
#endif /* !defined (timing_h_included) */