File: qsort_override.c

package info (click to toggle)
aws-crt-python 0.20.4%2Bdfsg-1~bpo12%2B1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-backports
  • size: 72,656 kB
  • sloc: ansic: 381,805; python: 23,008; makefile: 6,251; sh: 4,536; cpp: 699; ruby: 208; java: 77; perl: 73; javascript: 46; xml: 11
file content (17 lines) | stat: -rw-r--r-- 702 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
/**
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * SPDX-License-Identifier: Apache-2.0.
 */

#include <stdint.h>

void qsort(void *base, __CPROVER_size_t num, __CPROVER_size_t size, int (*compare)(const void *, const void *)) {
    __CPROVER_precondition(__CPROVER_r_ok(base, num * size), "qsort base region readable");
    __CPROVER_precondition(__CPROVER_w_ok(base, num * size), "qsort base region writeable");
    __CPROVER_size_t index_a;
    __CPROVER_assume(index_a < num);
    __CPROVER_size_t index_b;
    __CPROVER_assume(index_b < num);
    __CPROVER_assume(index_a != index_b);
    compare((uint8_t *)base + (size * index_a), (uint8_t *)base + (size * index_b));
}