blob: 23d6174054f0d18a56b3e2c9de0bcc27757c2d59 (
plain) (
blame)
| 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 KLEE_CONSTANTDIVISION_H
#define KLEE_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 /* KLEE_CONSTANTDIVISION_H */
 |