package goblint-cil
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  A front-end for the C programming language that facilitates program analysis and transformation
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      goblint-cil-2.0.1.tbz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=5f81cb3f25c09770e77b5eb4092e6621e456122b6d1219dcc304c062075f9572
    
    
  sha512=31bb753031e0ef321a2ef065373009270881b1cce7f23167b378845188aed9cb49f18a165edd2e11f751f2c7a7b84ab5ac1da50ba1f5cb975e6e8a97157838ed
    
    
  doc/src/goblint-cil/cilint.ml.html
Source file cilint.ml
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 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153(* cilint: infinite-precision, 2's complement arithmetic. *) (* An infinite-precision 2's complement number is a good way of understanding the meaning of bitwise operations on infinite precision numbers: positive numbers have the normal base-2 representation, while negative numbers are represented in a 2's complement representation with an infinite series of leading 1 bits. I.e., 3 = ...0000000000011 -3 = ...1111111111101 We represent cilints using a big_int but define some operations differently *) open Big_int_Z type cilint = big_int type truncation = NoTruncation | ValueTruncation | BitTruncation let zero_cilint = zero_big_int let one_cilint = unit_big_int let mone_cilint = minus_big_int unit_big_int (* Precompute useful big_ints *) let b30 = shift_left_big_int unit_big_int 30 let m1 = minus_big_int unit_big_int (* True if 'b' is all 0's or all 1's *) let nobits (b:big_int) : bool = sign_big_int b = 0 || compare_big_int b m1 = 0 let big_int_of_cilint (c:cilint) : big_int = c let cilint_of_big_int (b:big_int) : cilint = b let neg_cilint = minus_big_int let add_cilint = add_big_int let sub_cilint = sub_big_int let mul_cilint = mult_big_int let div_cilint = div_big_int let mod_cilint = mod_big_int let compare_cilint = compare_big_int let is_zero_cilint (c:cilint) : bool = sign_big_int c = 0 let cilint_of_int = big_int_of_int let int_of_cilint = int_of_big_int let cilint_of_int64 (i64:int64) : cilint = big_int_of_int64 i64 (* Note that this never fails, instead it returns the low-order 64-bits of the cilint. *) let int64_of_cilint (b:cilint) : int64 = let rec loop b mul acc = if sign_big_int b = 0 then acc else if compare_big_int b m1 == 0 then Int64.sub acc mul else let hi, lo = quomod_big_int b b30 in loop hi (Int64.mul mul 0x40000000L) (Int64.add acc (Int64.mul mul (Int64.of_int (int_of_big_int lo)))) in loop b 1L 0L let cilint_of_string = big_int_of_string let string_of_cilint = string_of_big_int (* Divide rounding towards zero *) let div0_cilint (c1:cilint) (c2:cilint) = let q, r = quomod_big_int c1 c2 in if lt_big_int c1 zero_big_int && (not (eq_big_int r zero_big_int)) then if gt_big_int c2 zero_big_int then (succ_big_int q) else (pred_big_int q) else q (* And the corresponding remainder! Different from *) (* Big_int_Z.mod_big_int computes the Euclidian Modulus, but what we want here is the remainder, as returned by mod on ints -1 rem 5 == -1, whereas -1 Euclid-Mod 5 == 4 *) let rem_cilint (c1:cilint) (c2:cilint) = (sub_cilint c1 (mul_cilint c2 (div0_cilint c1 c2))) (* Perform logical op 'op' over 'int' on two cilints. Does it work 30-bits at a time as that is guaranteed to fit in an 'int'. *) let logop op c1 c2 = let rec loop b1 b2 mul acc = if nobits b1 && nobits b2 then (* Once we only have all-0/all-1 values left, we can find whether the infinite high-order bits are all-0 or all-1 by checking the behaviour of op on b1 and b2. *) if op (int_of_big_int b1) (int_of_big_int b2) = 0 then acc else sub_big_int acc mul else let hi1, lo1 = quomod_big_int b1 b30 in let hi2, lo2 = quomod_big_int b2 b30 in let lo = op (int_of_big_int lo1) (int_of_big_int lo2) in loop hi1 hi2 (mult_big_int mul b30) (add_big_int acc (mult_big_int mul (big_int_of_int lo))) in loop c1 c2 unit_big_int zero_big_int let logand_cilint = logop (land) let logor_cilint = logop (lor) let logxor_cilint = logop (lxor) let shift_right_cilint (c1:cilint) (n:int) : cilint = shift_right_towards_zero_big_int c1 n let shift_left_cilint (c1:cilint) (n:int) : cilint = shift_left_big_int c1 n let lognot_cilint (c1:cilint) : cilint = (pred_big_int (minus_big_int c1)) let truncate_signed_cilint (c:cilint) (n:int) : cilint * truncation = let max = shift_left_big_int unit_big_int (n - 1) in let truncmax = shift_left_big_int unit_big_int n in let bits = mod_big_int c truncmax in let tval = if lt_big_int bits max then bits else sub_big_int bits truncmax in let trunc = if ge_big_int c max || lt_big_int c (minus_big_int max) then if ge_big_int c truncmax then BitTruncation else ValueTruncation else NoTruncation in tval, trunc let truncate_unsigned_cilint (c:cilint) (n:int) : cilint * truncation = let max = shift_left_big_int unit_big_int (n - 1) in let truncmax = shift_left_big_int unit_big_int n in let bits = mod_big_int c truncmax in let trunc = if ge_big_int c truncmax || lt_big_int c zero_big_int then if lt_big_int c (minus_big_int max) then BitTruncation else ValueTruncation else NoTruncation in bits, trunc let is_int_cilint (c:cilint) : bool = is_int_big_int c
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >