Skip to content
Snippets Groups Projects
cwe190.c 1005 B
Newer Older
Andre Maroneze's avatar
Andre Maroneze committed
// Based on MITRE's CWE-190, demonstrative example 2
// https://cwe.mitre.org/data/definitions/190.html

Andre Maroneze's avatar
Andre Maroneze committed
#include <stdlib.h>

volatile size_t _rand;
// returns a random size_t
size_t random_size_t(void) {
size_t packet_get_size_t_ok() {
  return random_size_t() ? 0 : 123456; // ok size
Andre Maroneze's avatar
Andre Maroneze committed
}

size_t packet_get_size_t_problem() {
  return random_size_t() ? (SIZE_MAX/2+1) : 0; // too large
Andre Maroneze's avatar
Andre Maroneze committed
}

char *packet_get_string(const char *s) {
  return "string";
}

int main() {
  char **response;
  size_t nresp = packet_get_size_t_ok();
Andre Maroneze's avatar
Andre Maroneze committed
  if (nresp > 0) {
    response = malloc(nresp*sizeof(char*));
    if (!response) exit(1);
    for (size_t i = 0; i < nresp; i++) response[i] = packet_get_string(NULL);
Andre Maroneze's avatar
Andre Maroneze committed
  }

Andre Maroneze's avatar
Andre Maroneze committed
  if (nresp > 0) {
    response = malloc(nresp*sizeof(char*));
    if (!response) exit(1);
    for (size_t i = 0; i < nresp; i++) response[i] = packet_get_string(NULL);
Andre Maroneze's avatar
Andre Maroneze committed
  }
  return 0;
}