Hi,

I'm trying to implement a tree pass that warns about bad array
accesses as suggested for PR 8268 by Jeff Law. However, I have trouble
with the following:

char digit_vector[5];
const char *ggc_alloc_string(int length) {
    return digit_vector + ((length - 17) * 2);
}

this translates to:

ggc_alloc_string (length)
{
  const char * D.1292;
  int D.1293;
  long unsigned int D.1294;
  char * D.1295;
  char * D.1296;

  D.1293 = length * 2;
  D.1294 = (long unsigned int) D.1293;
  D.1295 = (char *) D.1294;
  D.1296 = &digit_vector + -34B;     <-----------
  D.1292 = D.1295 + D.1296;
  return D.1292;
}

that is, a pointer is formed that wouldn't be legal to form from C,
and we end up with

  return (char *) (long unsigned int) (length * 2) + &digit_vector[-000000022];

producing a warning. Is that correct GIMPLE? If so, I fear it simply
isn't possible to do this kind of warnings after gimplification, and,
if at all possible, would have to be done in the front-end after all.

-- 
        Falk

Reply via email to