Commit 71ab36e
authored
Support pointer arithmetic in quantifier predicates (#4583)
Lower wrapping pointer arithmetic intrinsics (`wrapping_add`,
`wrapping_byte_offset`) directly to CBMC pointer `Plus` expressions in
the pure expression inliner. These intrinsics have no GOTO body to
inline, so they need special handling.
## Problem
Quantifier predicates that dereference pointers with offsets — e.g.,
`*ptr.wrapping_byte_offset(i as isize)` — failed because the
`inline_as_pure_expr` inliner couldn't resolve pointer arithmetic
intrinsics. These functions have no body in the symbol table (they're
compiler intrinsics), so the inliner returned the original expression
unchanged, leaving unresolved function calls that CBMC rejected.
## Solution
In `inline_call_as_pure_expr` (`goto_ctx.rs`), before attempting to look
up the function body, check if the function name matches a known
wrapping pointer arithmetic intrinsic (`wrapping_add`,
`wrapping_byte_offset`). If so, directly emit `ptr.plus(offset)` — the
CBMC expression for pointer arithmetic. A type guard
(`arguments[0].typ().is_pointer()`) prevents misapplication to
non-pointer functions.
Non-wrapping variants (`offset`, `add`, `arith_offset`) are
intentionally excluded because they trigger CBMC bounds checks inside
quantifier bodies, which fail in the symbolic evaluation context.
## Example
```rust
kani::forall!(|i in (0, len)| unsafe { *ptr.wrapping_byte_offset(i as isize) == 0 })
```
## Changes
- `goto_ctx.rs`: Recognize wrapping pointer arithmetic intrinsics and
lower to `ptr.plus(offset)`
- `rfc/src/rfcs/0010-quantifiers.md`: Document pointer arithmetic
intrinsic lowering in the Detailed Design section
- `tests/kani/Quantifiers/pointer_arithmetic.rs`: 4 harnesses covering
`wrapping_byte_offset` (forall + exists) and `wrapping_add` (u32 + u8)
---
By submitting this pull request, I confirm that my contribution is made
under the terms of the Apache 2.0 and MIT licenses.1 parent 047c6b6 commit 71ab36e
3 files changed
Lines changed: 154 additions & 0 deletions
File tree
- kani-compiler/src/codegen_cprover_gotoc/context
- rfc/src/rfcs
- tests/kani/Quantifiers
Lines changed: 50 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
515 | 515 | | |
516 | 516 | | |
517 | 517 | | |
| 518 | + | |
| 519 | + | |
| 520 | + | |
| 521 | + | |
| 522 | + | |
| 523 | + | |
| 524 | + | |
| 525 | + | |
| 526 | + | |
| 527 | + | |
| 528 | + | |
| 529 | + | |
| 530 | + | |
| 531 | + | |
| 532 | + | |
| 533 | + | |
| 534 | + | |
| 535 | + | |
| 536 | + | |
| 537 | + | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
| 543 | + | |
| 544 | + | |
| 545 | + | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
| 565 | + | |
| 566 | + | |
| 567 | + | |
518 | 568 | | |
519 | 569 | | |
520 | 570 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
234 | 234 | | |
235 | 235 | | |
236 | 236 | | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
237 | 250 | | |
238 | 251 | | |
239 | 252 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 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 | + | |
0 commit comments