Imported Upstream version 1.1.11
[platform/upstream/cdrkit.git] / libusal / usaltimes.c
1 /*
2  * This file has been modified for the cdrkit suite.
3  *
4  * The behaviour and appearence of the program code below can differ to a major
5  * extent from the version distributed by the original author(s).
6  *
7  * For details, see Changelog file distributed with the cdrkit package. If you
8  * received this file from another source then ask the distributing person for
9  * a log of modifications.
10  *
11  */
12
13 /* @(#)usaltimes.c      1.1 00/08/25 Copyright 1995,2000 J. Schilling */
14 /*
15  *      SCSI user level command timing
16  *
17  *      Copyright (c) 1995,2000 J. Schilling
18  */
19 /*
20  * This program is free software; you can redistribute it and/or modify
21  * it under the terms of the GNU General Public License version 2
22  * as published by the Free Software Foundation.
23  *
24  * This program is distributed in the hope that it will be useful,
25  * but WITHOUT ANY WARRANTY; without even the implied warranty of
26  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
27  * GNU General Public License for more details.
28  *
29  * You should have received a copy of the GNU General Public License along with
30  * this program; see the file COPYING.  If not, write to the Free Software
31  * Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
32  */
33
34 #include <mconfig.h>
35 #include <standard.h>
36 #include <timedefs.h>
37 #include <schily.h>
38
39 #include <usal/scsitransp.h>
40 #include "usaltimes.h"
41
42 void    __usal_times(SCSI *usalp);
43
44 /*
45  * We don't like to make this a public interface to prevent bad users
46  * from making our timing incorrect.
47  */
48 void
49 __usal_times(SCSI *usalp)
50 {
51         struct timeval  *stp = usalp->cmdstop;
52
53         gettimeofday(stp, (struct timezone *)0);
54         stp->tv_sec -= usalp->cmdstart->tv_sec;
55         stp->tv_usec -= usalp->cmdstart->tv_usec;
56         while (stp->tv_usec < 0) {
57                 stp->tv_sec -= 1;
58                 stp->tv_usec += 1000000;
59         }
60 }