private static JavaType asJavaType(
     Class<?> type, MetaAccessProvider metaAccess, CodeCacheProvider codeCache) {
   if (WordBase.class.isAssignableFrom(type)) {
     return metaAccess.lookupJavaType(codeCache.getTarget().wordJavaKind.toJavaClass());
   } else {
     return metaAccess.lookupJavaType(type);
   }
 }
 public Signature getSignature() {
   ForeignCallDescriptor d = linkage.getDescriptor();
   MetaAccessProvider metaAccess = providers.getMetaAccess();
   Class<?>[] arguments = d.getArgumentTypes();
   ResolvedJavaType[] parameters = new ResolvedJavaType[arguments.length];
   for (int i = 0; i < arguments.length; i++) {
     parameters[i] = metaAccess.lookupJavaType(arguments[i]);
   }
   return new HotSpotSignature(
       jvmciRuntime, metaAccess.lookupJavaType(d.getResultType()), parameters);
 }
 /**
  * Gets a {@link Classfile} created by parsing the class file bytes for {@code c}.
  *
  * @throws NoClassDefFoundError if the class file cannot be found
  */
 private synchronized Classfile getClassfile(Class<?> c) {
   assert !c.isPrimitive() && !c.isArray() : c;
   Classfile classfile = classfiles.get(c);
   if (classfile == null) {
     try {
       ResolvedJavaType type = metaAccess.lookupJavaType(c);
       InputStream in = getClassfileAsStream(c);
       if (in != null) {
         DataInputStream stream = new DataInputStream(in);
         classfile = new Classfile(type, stream, this);
         classfiles.put(c, classfile);
         return classfile;
       }
       throw new NoClassDefFoundError(c.getName());
     } catch (IOException e) {
       throw (NoClassDefFoundError) new NoClassDefFoundError(c.getName()).initCause(e);
     }
   }
   return classfile;
 }