Mercurial > hg > truffle
diff src/share/vm/c1/c1_InstructionPrinter.cpp @ 6725:da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
Summary: Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
Contributed-by: jmasa <jon.masamitsu@oracle.com>, stefank <stefan.karlsson@oracle.com>, mgerdin <mikael.gerdin@oracle.com>, never <tom.rodriguez@oracle.com>
author | coleenp |
---|---|
date | Sat, 01 Sep 2012 13:25:18 -0400 |
parents | 1d7922586cf6 |
children | 7eca5de9e0b6 |
line wrap: on
line diff
--- a/src/share/vm/c1/c1_InstructionPrinter.cpp Fri Aug 31 16:39:35 2012 -0700 +++ b/src/share/vm/c1/c1_InstructionPrinter.cpp Sat Sep 01 13:25:18 2012 -0400 @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -133,9 +133,6 @@ output()->print("null"); } else if (!value->is_loaded()) { output()->print("<unloaded object " PTR_FORMAT ">", value); - } else if (value->is_method()) { - ciMethod* m = (ciMethod*)value; - output()->print("<method %s.%s>", m->holder()->name()->as_utf8(), m->name()->as_utf8()); } else { output()->print("<object " PTR_FORMAT " klass=", value->constant_encoding()); print_klass(value->klass()); @@ -159,6 +156,9 @@ } output()->print("class "); print_klass(klass); + } else if (type->as_MethodConstant() != NULL) { + ciMethod* m = type->as_MethodConstant()->value(); + output()->print("<method %s.%s>", m->holder()->name()->as_utf8(), m->name()->as_utf8()); } else { output()->print("???"); } @@ -461,7 +461,10 @@ output()->print("type_cast("); print_value(x->obj()); output()->print(") "); - print_klass(x->declared_type()->klass()); + if (x->declared_type()->is_klass()) + print_klass(x->declared_type()->as_klass()); + else + output()->print(type2name(x->declared_type()->basic_type())); }