blob: 2ca9039fc73c832dad6c7bbd5464cfba1fd301fb [file] [log] [blame]
Sushil Chauhan0568ff12016-12-28 15:18:14 -08001/*
Sushil Chauhan40c8cf52016-12-19 19:18:10 -08002* Copyright (c) 2016 - 2017, The Linux Foundation. All rights reserved.
Sushil Chauhan0568ff12016-12-28 15:18:14 -08003*
4* Redistribution and use in source and binary forms, with or without
5* modification, are permitted provided that the following conditions are
6* met:
7* * Redistributions of source code must retain the above copyright
8* notice, this list of conditions and the following disclaimer.
9* * Redistributions in binary form must reproduce the above
10* copyright notice, this list of conditions and the following
11* disclaimer in the documentation and/or other materials provided
12* with the distribution.
13* * Neither the name of The Linux Foundation nor the names of its
14* contributors may be used to endorse or promote products derived
15* from this software without specific prior written permission.
16*
17* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
18* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
20* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
21* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
24* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
26* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
27* IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*/
29
Sushil Chauhan40c8cf52016-12-19 19:18:10 -080030#include <utils/sys.h>
Sushil Chauhan0568ff12016-12-28 15:18:14 -080031#include <math.h>
32#include <algorithm>
33
34#define __CLASS__ "Utils"
35
36namespace sdm {
37
38float gcd(float a, float b) {
39 if (a < b) {
40 std::swap(a, b);
41 }
42
43 while (b != 0) {
44 float tmp = b;
45 b = fmodf(a, b);
46 a = tmp;
47 }
48
49 return a;
50}
51
52float lcm(float a, float b) {
53 return (a * b) / gcd(a, b);
54}
55
Sushil Chauhan40c8cf52016-12-19 19:18:10 -080056void CloseFd(int *fd) {
57 if (*fd >= 0) {
58 Sys::close_(*fd);
59 *fd = -1;
60 }
61}
62
Sushil Chauhan0568ff12016-12-28 15:18:14 -080063} // namespace sdm