OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gcc-4.2.2/] [gcc/] [testsuite/] [g++.dg/] [eh/] [delayslot1.C] - Rev 816

Compare with Previous | Blame | View Log

// PR target/12301
// Origin: Colin Hirsch <gcc@cohi.at>
// Testcase by Christian Ehrhardt <ehrhardt@mathematik.uni-ulm.de>

// This used to fail on SPARC because the reorg pass moved an insn
// across a function call that can throw internally, in order to put
// it in a delay slot.

// { dg-do run }
// { dg-options "-O" }

struct S{
  char *c;
  char data[100];
  S () : c (data) {};
  S (const S& s) {
    c = data;
    data[0] = s.c[0];
  }
};

S real_cast ()
{
  throw 3;  
}

S cast_helper(S& debug)
{
  try {
    return real_cast();
  }
  catch (int e) {
    throw debug;
  }
}

int main()
{
  S tmp;

  try {
    cast_helper (tmp);
  }                                        
  catch (S& e) {}

  return 0;
}

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.