summaryrefslogtreecommitdiff
path: root/klee/lib/Solver/ConstantDivision.h
blob: 9e3e9c9554366a1dd49d6c75c4481202113d849b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
//===-- ConstantDivision.h --------------------------------------*- C++ -*-===//
//
//                     The KLEE Symbolic Virtual Machine
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//

#ifndef __UTIL_CONSTANTDIVISION_H__
#define __UTIL_CONSTANTDIVISION_H__

#include <stdint.h>

namespace klee {

/// ComputeMultConstants64 - Compute add and sub such that add-sub==x,
/// while attempting to minimize the number of bits in add and sub
/// combined.
void ComputeMultConstants64(uint64_t x, uint64_t &add_out, 
                            uint64_t &sub_out);

/// Compute the constants to perform a quicker equivalent of a division of some 
/// 32-bit unsigned integer n by a known constant d (also a 32-bit unsigned 
/// integer).  The constants to compute n/d without explicit division will be 
/// stored in mprime, sh1, and sh2 (unsigned 32-bit integers).
/// 
/// @param d - denominator (divisor)
/// 
/// @param [out] mprime
/// @param [out] sh1
/// @param [out] sh2
void ComputeUDivConstants32(uint32_t d, uint32_t &mprime, uint32_t &sh1, 
                            uint32_t &sh2);

/// Compute the constants to perform a quicker equivalent of a division of some 
/// 32-bit signed integer n by a known constant d (also a 32-bit signed 
/// integer).  The constants to compute n/d without explicit division will be 
/// stored in mprime, dsign, and shpost (signed 32-bit integers).
/// 
/// @param d - denominator (divisor)
/// 
/// @param [out] mprime
/// @param [out] dsign
/// @param [out] shpost
void ComputeSDivConstants32(int32_t d, int32_t &mprime, int32_t &dsign, 
                            int32_t &shpost);

}

#endif