Home | History | Annotate | Download | only in bcinfo
      1 /*
      2  * Copyright 2011-2012, The Android Open Source Project
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License");
      5  * you may not use this file except in compliance with the License.
      6  * You may obtain a copy of the License at
      7  *
      8  *     http://www.apache.org/licenses/LICENSE-2.0
      9  *
     10  * Unless required by applicable law or agreed to in writing, software
     11  * distributed under the License is distributed on an "AS IS" BASIS,
     12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13  * See the License for the specific language governing permissions and
     14  * limitations under the License.
     15  */
     16 
     17 #include "bcinfo/MetadataExtractor.h"
     18 
     19 #include "bcinfo/BitcodeWrapper.h"
     20 #include "rsDefines.h"
     21 
     22 #define LOG_TAG "bcinfo"
     23 #include <log/log.h>
     24 
     25 #include "Assert.h"
     26 
     27 #include "llvm/Bitcode/ReaderWriter.h"
     28 #include "llvm/IR/Constants.h"
     29 #include "llvm/IR/LLVMContext.h"
     30 #include "llvm/IR/Module.h"
     31 #include "llvm/IR/Function.h"
     32 #include "llvm/Support/MemoryBuffer.h"
     33 
     34 #ifdef __ANDROID__
     35 #include "Properties.h"
     36 #endif
     37 
     38 #include <cstdlib>
     39 
     40 namespace bcinfo {
     41 
     42 namespace {
     43 
     44 llvm::StringRef getStringOperand(const llvm::Metadata *node) {
     45   if (auto *mds = llvm::dyn_cast_or_null<const llvm::MDString>(node)) {
     46     return mds->getString();
     47   }
     48   return llvm::StringRef();
     49 }
     50 
     51 bool extractUIntFromMetadataString(uint32_t *value,
     52     const llvm::Metadata *m) {
     53   llvm::StringRef SigString = getStringOperand(m);
     54   if (SigString != "") {
     55     if (!SigString.getAsInteger(10, *value)) {
     56       return true;
     57     }
     58   }
     59   return false;
     60 }
     61 
     62 const char *createStringFromValue(llvm::Metadata *m) {
     63   auto ref = getStringOperand(m);
     64   char *c = new char[ref.size() + 1];
     65   memcpy(c, ref.data(), ref.size());
     66   c[ref.size()] = '\0';
     67   return c;
     68 }
     69 
     70 const char *createStringFromOptionalValue(llvm::MDNode *n, unsigned opndNum) {
     71   llvm::Metadata *opnd;
     72   if (opndNum >= n->getNumOperands() || !(opnd = n->getOperand(opndNum)))
     73     return nullptr;
     74   return createStringFromValue(opnd);
     75 }
     76 
     77 // Collect metadata from NamedMDNodes that contain a list of names
     78 // (strings).
     79 //
     80 // Inputs:
     81 //
     82 // NamedMetadata - An LLVM metadata node, each of whose operands have
     83 // a string as their first entry
     84 //
     85 // NameList - A reference that will hold an allocated array of strings
     86 //
     87 // Count - A reference that will hold the length of the allocated
     88 // array of strings
     89 //
     90 // Return value:
     91 //
     92 // Return true on success, false on error.
     93 //
     94 // Upon success, the function sets NameList to an array of strings
     95 // corresponding the names found in the metadata. The function sets
     96 // Count to the number of entries in NameList.
     97 //
     98 // An error occurs if one of the metadata operands doesn't have a
     99 // first entry.
    100 bool populateNameMetadata(const llvm::NamedMDNode *NameMetadata,
    101                           const char **&NameList, size_t &Count) {
    102   if (!NameMetadata) {
    103     NameList = nullptr;
    104     Count = 0;
    105     return true;
    106   }
    107 
    108   Count = NameMetadata->getNumOperands();
    109   if (!Count) {
    110     NameList = nullptr;
    111     return true;
    112   }
    113 
    114   NameList = new const char *[Count];
    115 
    116   for (size_t i = 0; i < Count; i++) {
    117     llvm::MDNode *Name = NameMetadata->getOperand(i);
    118     if (Name && Name->getNumOperands() > 0) {
    119       NameList[i] = createStringFromValue(Name->getOperand(0));
    120     } else {
    121       ALOGE("Metadata operand does not contain a name string");
    122       for (size_t AllocatedIndex = 0; AllocatedIndex < i; AllocatedIndex++) {
    123         delete [] NameList[AllocatedIndex];
    124       }
    125       delete [] NameList;
    126       NameList = nullptr;
    127       Count = 0;
    128 
    129       return false;
    130     }
    131   }
    132 
    133   return true;
    134 }
    135 
    136 } // end anonymous namespace
    137 
    138 // Name of metadata node where pragma info resides (should be synced with
    139 // slang.cpp)
    140 static const llvm::StringRef PragmaMetadataName = "#pragma";
    141 
    142 // Name of metadata node where exported variable names reside (should be
    143 // synced with slang_rs_metadata.h)
    144 static const llvm::StringRef ExportVarMetadataName = "#rs_export_var";
    145 
    146 // Name of metadata node where exported function names reside (should be
    147 // synced with slang_rs_metadata.h)
    148 static const llvm::StringRef ExportFuncMetadataName = "#rs_export_func";
    149 
    150 // Name of metadata node where exported ForEach name information resides
    151 // (should be synced with slang_rs_metadata.h)
    152 static const llvm::StringRef ExportForEachNameMetadataName =
    153     "#rs_export_foreach_name";
    154 
    155 // Name of metadata node where exported ForEach signature information resides
    156 // (should be synced with slang_rs_metadata.h)
    157 static const llvm::StringRef ExportForEachMetadataName = "#rs_export_foreach";
    158 
    159 // Name of metadata node where exported general reduce information resides
    160 // (should be synced with slang_rs_metadata.h)
    161 static const llvm::StringRef ExportReduceMetadataName = "#rs_export_reduce";
    162 
    163 // Name of metadata node where RS object slot info resides (should be
    164 // synced with slang_rs_metadata.h)
    165 static const llvm::StringRef ObjectSlotMetadataName = "#rs_object_slots";
    166 
    167 static const llvm::StringRef ThreadableMetadataName = "#rs_is_threadable";
    168 
    169 // Name of metadata node where the checksum for this build is stored.  (should
    170 // be synced with libbcc/lib/Core/Source.cpp)
    171 static const llvm::StringRef ChecksumMetadataName = "#rs_build_checksum";
    172 
    173 // Name of metadata node which contains a list of compile units that have debug
    174 // metadata. If this is null then there is no debug metadata in the compile
    175 // unit.
    176 static const llvm::StringRef DebugInfoMetadataName = "llvm.dbg.cu";
    177 
    178 const char MetadataExtractor::kWrapperMetadataName[] = "#rs_wrapper";
    179 
    180 MetadataExtractor::MetadataExtractor(const char *bitcode, size_t bitcodeSize)
    181     : mModule(nullptr), mBitcode(bitcode), mBitcodeSize(bitcodeSize),
    182       mExportVarCount(0), mExportFuncCount(0), mExportForEachSignatureCount(0),
    183       mExportReduceCount(0), mExportVarNameList(nullptr),
    184       mExportFuncNameList(nullptr), mExportForEachNameList(nullptr),
    185       mExportForEachSignatureList(nullptr),
    186       mExportForEachInputCountList(nullptr),
    187       mExportReduceList(nullptr),
    188       mPragmaCount(0), mPragmaKeyList(nullptr), mPragmaValueList(nullptr),
    189       mObjectSlotCount(0), mObjectSlotList(nullptr),
    190       mRSFloatPrecision(RS_FP_Full), mIsThreadable(true),
    191       mBuildChecksum(nullptr), mHasDebugInfo(false) {
    192   BitcodeWrapper wrapper(bitcode, bitcodeSize);
    193   mCompilerVersion = wrapper.getCompilerVersion();
    194   mOptimizationLevel = wrapper.getOptimizationLevel();
    195 }
    196 
    197 MetadataExtractor::MetadataExtractor(const llvm::Module *module)
    198     : mModule(module), mBitcode(nullptr), mBitcodeSize(0),
    199       mExportVarCount(0), mExportFuncCount(0), mExportForEachSignatureCount(0),
    200       mExportReduceCount(0), mExportVarNameList(nullptr),
    201       mExportFuncNameList(nullptr), mExportForEachNameList(nullptr),
    202       mExportForEachSignatureList(nullptr),
    203       mExportForEachInputCountList(nullptr),
    204       mExportReduceList(nullptr),
    205       mPragmaCount(0), mPragmaKeyList(nullptr), mPragmaValueList(nullptr),
    206       mObjectSlotCount(0), mObjectSlotList(nullptr),
    207       mRSFloatPrecision(RS_FP_Full), mIsThreadable(true),
    208       mBuildChecksum(nullptr) {
    209   const llvm::NamedMDNode *const wrapperMDNode = module->getNamedMetadata(kWrapperMetadataName);
    210   bccAssert((wrapperMDNode != nullptr) && (wrapperMDNode->getNumOperands() == 1));
    211   const llvm::MDNode *const wrapperMDTuple = wrapperMDNode->getOperand(0);
    212 
    213   bool success = true;
    214   success &= extractUIntFromMetadataString(&mCompilerVersion, wrapperMDTuple->getOperand(0));
    215   success &= extractUIntFromMetadataString(&mOptimizationLevel, wrapperMDTuple->getOperand(1));
    216   bccAssert(success);
    217 }
    218 
    219 
    220 MetadataExtractor::~MetadataExtractor() {
    221   if (mExportVarNameList) {
    222     for (size_t i = 0; i < mExportVarCount; i++) {
    223         delete [] mExportVarNameList[i];
    224         mExportVarNameList[i] = nullptr;
    225     }
    226   }
    227   delete [] mExportVarNameList;
    228   mExportVarNameList = nullptr;
    229 
    230   if (mExportFuncNameList) {
    231     for (size_t i = 0; i < mExportFuncCount; i++) {
    232         delete [] mExportFuncNameList[i];
    233         mExportFuncNameList[i] = nullptr;
    234     }
    235   }
    236   delete [] mExportFuncNameList;
    237   mExportFuncNameList = nullptr;
    238 
    239   if (mExportForEachNameList) {
    240     for (size_t i = 0; i < mExportForEachSignatureCount; i++) {
    241         delete [] mExportForEachNameList[i];
    242         mExportForEachNameList[i] = nullptr;
    243     }
    244   }
    245   delete [] mExportForEachNameList;
    246   mExportForEachNameList = nullptr;
    247 
    248   delete [] mExportForEachSignatureList;
    249   mExportForEachSignatureList = nullptr;
    250 
    251   delete [] mExportForEachInputCountList;
    252   mExportForEachInputCountList = nullptr;
    253 
    254   delete [] mExportReduceList;
    255   mExportReduceList = nullptr;
    256 
    257   for (size_t i = 0; i < mPragmaCount; i++) {
    258     if (mPragmaKeyList) {
    259       delete [] mPragmaKeyList[i];
    260       mPragmaKeyList[i] = nullptr;
    261     }
    262     if (mPragmaValueList) {
    263       delete [] mPragmaValueList[i];
    264       mPragmaValueList[i] = nullptr;
    265     }
    266   }
    267   delete [] mPragmaKeyList;
    268   mPragmaKeyList = nullptr;
    269   delete [] mPragmaValueList;
    270   mPragmaValueList = nullptr;
    271 
    272   delete [] mObjectSlotList;
    273   mObjectSlotList = nullptr;
    274 
    275   delete [] mBuildChecksum;
    276 
    277   return;
    278 }
    279 
    280 
    281 bool MetadataExtractor::populateObjectSlotMetadata(
    282     const llvm::NamedMDNode *ObjectSlotMetadata) {
    283   if (!ObjectSlotMetadata) {
    284     return true;
    285   }
    286 
    287   mObjectSlotCount = ObjectSlotMetadata->getNumOperands();
    288 
    289   if (!mObjectSlotCount) {
    290     return true;
    291   }
    292 
    293   std::unique_ptr<uint32_t[]> TmpSlotList(new uint32_t[mObjectSlotCount]());
    294   for (size_t i = 0; i < mObjectSlotCount; i++) {
    295     llvm::MDNode *ObjectSlot = ObjectSlotMetadata->getOperand(i);
    296     if (ObjectSlot != nullptr && ObjectSlot->getNumOperands() == 1) {
    297       if (!extractUIntFromMetadataString(&TmpSlotList[i], ObjectSlot->getOperand(0))) {
    298         ALOGE("Non-integer object slot value");
    299         return false;
    300       }
    301     } else {
    302       ALOGE("Corrupt object slot information");
    303       return false;
    304     }
    305   }
    306 
    307   delete [] mObjectSlotList;
    308   mObjectSlotList = TmpSlotList.release();
    309   return true;
    310 }
    311 
    312 
    313 void MetadataExtractor::populatePragmaMetadata(
    314     const llvm::NamedMDNode *PragmaMetadata) {
    315   if (!PragmaMetadata) {
    316     return;
    317   }
    318 
    319   mPragmaCount = PragmaMetadata->getNumOperands();
    320   if (!mPragmaCount) {
    321     return;
    322   }
    323 
    324   const char **TmpKeyList = new const char*[mPragmaCount];
    325   const char **TmpValueList = new const char*[mPragmaCount];
    326 
    327   for (size_t i = 0; i < mPragmaCount; i++) {
    328     llvm::MDNode *Pragma = PragmaMetadata->getOperand(i);
    329     if (Pragma != nullptr && Pragma->getNumOperands() == 2) {
    330       llvm::Metadata *PragmaKeyMDS = Pragma->getOperand(0);
    331       TmpKeyList[i] = createStringFromValue(PragmaKeyMDS);
    332       llvm::Metadata *PragmaValueMDS = Pragma->getOperand(1);
    333       TmpValueList[i] = createStringFromValue(PragmaValueMDS);
    334     }
    335   }
    336 
    337   mPragmaKeyList = TmpKeyList;
    338   mPragmaValueList = TmpValueList;
    339 
    340   // Check to see if we have any FP precision-related pragmas.
    341   std::string Relaxed("rs_fp_relaxed");
    342   std::string Imprecise("rs_fp_imprecise");
    343   std::string Full("rs_fp_full");
    344   bool RelaxedPragmaSeen = false;
    345   bool FullPragmaSeen = false;
    346   for (size_t i = 0; i < mPragmaCount; i++) {
    347     if (!Relaxed.compare(mPragmaKeyList[i])) {
    348       RelaxedPragmaSeen = true;
    349     } else if (!Imprecise.compare(mPragmaKeyList[i])) {
    350       ALOGW("rs_fp_imprecise is deprecated.  Assuming rs_fp_relaxed instead.");
    351       RelaxedPragmaSeen = true;
    352     } else if (!Full.compare(mPragmaKeyList[i])) {
    353       FullPragmaSeen = true;
    354     }
    355   }
    356 
    357   if (RelaxedPragmaSeen && FullPragmaSeen) {
    358     ALOGE("Full and relaxed precision specified at the same time!");
    359   }
    360   mRSFloatPrecision = RelaxedPragmaSeen ? RS_FP_Relaxed : RS_FP_Full;
    361 
    362 #ifdef __ANDROID__
    363   // Provide an override for precsiion via adb shell setprop
    364   // adb shell setprop debug.rs.precision rs_fp_full
    365   // adb shell setprop debug.rs.precision rs_fp_relaxed
    366   // adb shell setprop debug.rs.precision rs_fp_imprecise
    367   char PrecisionPropBuf[PROP_VALUE_MAX];
    368   const std::string PrecisionPropName("debug.rs.precision");
    369   property_get("debug.rs.precision", PrecisionPropBuf, "");
    370   if (PrecisionPropBuf[0]) {
    371     if (!Relaxed.compare(PrecisionPropBuf)) {
    372       ALOGI("Switching to RS FP relaxed mode via setprop");
    373       mRSFloatPrecision = RS_FP_Relaxed;
    374     } else if (!Imprecise.compare(PrecisionPropBuf)) {
    375       ALOGW("Switching to RS FP relaxed mode via setprop. rs_fp_imprecise was "
    376             "specified but is deprecated ");
    377       mRSFloatPrecision = RS_FP_Relaxed;
    378     } else if (!Full.compare(PrecisionPropBuf)) {
    379       ALOGI("Switching to RS FP full mode via setprop");
    380       mRSFloatPrecision = RS_FP_Full;
    381     } else {
    382       ALOGE("Unrecognized debug.rs.precision %s", PrecisionPropBuf);
    383     }
    384   }
    385 #endif
    386 }
    387 
    388 uint32_t MetadataExtractor::calculateNumInputs(const llvm::Function *Function,
    389                                                uint32_t Signature) {
    390 
    391   if (hasForEachSignatureIn(Signature)) {
    392     uint32_t OtherCount = 0;
    393 
    394     OtherCount += hasForEachSignatureUsrData(Signature);
    395     OtherCount += hasForEachSignatureX(Signature);
    396     OtherCount += hasForEachSignatureY(Signature);
    397     OtherCount += hasForEachSignatureZ(Signature);
    398     OtherCount += hasForEachSignatureCtxt(Signature);
    399     OtherCount += hasForEachSignatureOut(Signature) &&
    400                   Function->getReturnType()->isVoidTy();
    401 
    402     return Function->arg_size() - OtherCount;
    403 
    404   } else {
    405     return 0;
    406   }
    407 }
    408 
    409 
    410 bool MetadataExtractor::populateForEachMetadata(
    411     const llvm::NamedMDNode *Names,
    412     const llvm::NamedMDNode *Signatures) {
    413   if (!Names && !Signatures && mCompilerVersion == 0) {
    414     // Handle legacy case for pre-ICS bitcode that doesn't contain a metadata
    415     // section for ForEach. We generate a full signature for a "root" function
    416     // which means that we need to set the bottom 5 bits in the mask.
    417     mExportForEachSignatureCount = 1;
    418     char **TmpNameList = new char*[mExportForEachSignatureCount];
    419     size_t RootLen = strlen(kRoot) + 1;
    420     TmpNameList[0] = new char[RootLen];
    421     strncpy(TmpNameList[0], kRoot, RootLen);
    422 
    423     uint32_t *TmpSigList = new uint32_t[mExportForEachSignatureCount];
    424     TmpSigList[0] = 0x1f;
    425 
    426     mExportForEachNameList = (const char**)TmpNameList;
    427     mExportForEachSignatureList = TmpSigList;
    428     return true;
    429   }
    430 
    431   if (Signatures) {
    432     mExportForEachSignatureCount = Signatures->getNumOperands();
    433     if (!mExportForEachSignatureCount) {
    434       return true;
    435     }
    436   } else {
    437     mExportForEachSignatureCount = 0;
    438     mExportForEachSignatureList = nullptr;
    439     return true;
    440   }
    441 
    442   std::unique_ptr<uint32_t[]> TmpSigList(new uint32_t[mExportForEachSignatureCount]);
    443   std::unique_ptr<const char *[]> TmpNameList(new const char*[mExportForEachSignatureCount]);
    444   std::unique_ptr<uint32_t[]> TmpInputCountList(new uint32_t[mExportForEachSignatureCount]);
    445 
    446   for (size_t i = 0; i < mExportForEachSignatureCount; i++) {
    447     llvm::MDNode *SigNode = Signatures->getOperand(i);
    448     if (SigNode != nullptr && SigNode->getNumOperands() == 1) {
    449       if (!extractUIntFromMetadataString(&TmpSigList[i], SigNode->getOperand(0))) {
    450         ALOGE("Non-integer signature value");
    451         return false;
    452       }
    453     } else {
    454       ALOGE("Corrupt signature information");
    455       return false;
    456     }
    457   }
    458 
    459   if (Names) {
    460     for (size_t i = 0; i < mExportForEachSignatureCount; i++) {
    461       llvm::MDNode *Name = Names->getOperand(i);
    462       if (Name != nullptr && Name->getNumOperands() == 1) {
    463         TmpNameList[i] = createStringFromValue(Name->getOperand(0));
    464 
    465         // Note that looking up the function by name can fail: One of
    466         // the uses of MetadataExtractor is as part of the
    467         // RSEmbedInfoPass, which bcc_compat runs sufficiently late in
    468         // the phase order that RSKernelExpandPass has already run and
    469         // the original (UNexpanded) kernel function (TmpNameList[i])
    470         // may have been deleted as having no references (if it has
    471         // been inlined into the expanded kernel function and is
    472         // otherwise unreferenced).
    473         llvm::Function *Func =
    474             mModule->getFunction(llvm::StringRef(TmpNameList[i]));
    475 
    476         TmpInputCountList[i] = (Func != nullptr) ?
    477           calculateNumInputs(Func, TmpSigList[i]) : 0;
    478       }
    479     }
    480   } else {
    481     if (mExportForEachSignatureCount != 1) {
    482       ALOGE("mExportForEachSignatureCount = %zu, but should be 1",
    483             mExportForEachSignatureCount);
    484     }
    485     char *RootName = new char[5];
    486     strncpy(RootName, "root", 5);
    487     TmpNameList[0] = RootName;
    488   }
    489 
    490   delete [] mExportForEachNameList;
    491   mExportForEachNameList = TmpNameList.release();
    492 
    493   delete [] mExportForEachSignatureList;
    494   mExportForEachSignatureList = TmpSigList.release();
    495 
    496   delete [] mExportForEachInputCountList;
    497   mExportForEachInputCountList = TmpInputCountList.release();
    498 
    499   return true;
    500 }
    501 
    502 
    503 bool MetadataExtractor::populateReduceMetadata(const llvm::NamedMDNode *ReduceMetadata) {
    504   mExportReduceCount = 0;
    505   mExportReduceList = nullptr;
    506 
    507   if (!ReduceMetadata || !(mExportReduceCount = ReduceMetadata->getNumOperands()))
    508     return true;
    509 
    510   std::unique_ptr<Reduce[]> TmpReduceList(new Reduce[mExportReduceCount]);
    511 
    512   for (size_t i = 0; i < mExportReduceCount; i++) {
    513     llvm::MDNode *Node = ReduceMetadata->getOperand(i);
    514     if (!Node || Node->getNumOperands() < 3) {
    515       ALOGE("Missing reduce metadata");
    516       return false;
    517     }
    518 
    519     TmpReduceList[i].mReduceName = createStringFromValue(Node->getOperand(0));
    520 
    521     if (!extractUIntFromMetadataString(&TmpReduceList[i].mAccumulatorDataSize,
    522                                        Node->getOperand(1))) {
    523       ALOGE("Non-integer accumulator data size value in reduce metadata");
    524       return false;
    525     }
    526 
    527     llvm::MDNode *AccumulatorNode = llvm::dyn_cast<llvm::MDNode>(Node->getOperand(2));
    528     if (!AccumulatorNode || AccumulatorNode->getNumOperands() != 2) {
    529       ALOGE("Malformed accumulator node in reduce metadata");
    530       return false;
    531     }
    532     TmpReduceList[i].mAccumulatorName = createStringFromValue(AccumulatorNode->getOperand(0));
    533     if (!extractUIntFromMetadataString(&TmpReduceList[i].mSignature,
    534                                        AccumulatorNode->getOperand(1))) {
    535       ALOGE("Non-integer signature value in reduce metadata");
    536       return false;
    537     }
    538     // Note that looking up the function by name can fail: One of the
    539     // uses of MetadataExtractor is as part of the RSEmbedInfoPass,
    540     // which bcc_compat runs sufficiently late in the phase order that
    541     // RSKernelExpandPass has already run and the original
    542     // (UNexpanded) accumulator function (mAccumulatorName) may have
    543     // been deleted as having no references (if it has been inlined
    544     // into the expanded accumulator function and is otherwise
    545     // unreferenced).
    546     llvm::Function *Func =
    547         mModule->getFunction(llvm::StringRef(TmpReduceList[i].mAccumulatorName));
    548     // Why calculateNumInputs() - 1?  The "-1" is because we don't
    549     // want to treat the accumulator argument as an input.
    550     TmpReduceList[i].mInputCount = (Func ? calculateNumInputs(Func, TmpReduceList[i].mSignature) - 1 : 0);
    551 
    552     TmpReduceList[i].mInitializerName = createStringFromOptionalValue(Node, 3);
    553     TmpReduceList[i].mCombinerName = createStringFromOptionalValue(Node, 4);
    554     TmpReduceList[i].mOutConverterName = createStringFromOptionalValue(Node, 5);
    555     TmpReduceList[i].mHalterName = createStringFromOptionalValue(Node, 6);
    556   }
    557 
    558   mExportReduceList = TmpReduceList.release();
    559   return true;
    560 }
    561 
    562 void MetadataExtractor::readThreadableFlag(
    563     const llvm::NamedMDNode *ThreadableMetadata) {
    564 
    565   // Scripts are threadable by default.  If we read a valid metadata value for
    566   // 'ThreadableMetadataName' and it is set to 'no', we mark script as non
    567   // threadable.  All other exception paths retain the default value.
    568 
    569   mIsThreadable = true;
    570   if (ThreadableMetadata == nullptr)
    571     return;
    572 
    573   llvm::MDNode *mdNode = ThreadableMetadata->getOperand(0);
    574   if (mdNode == nullptr)
    575     return;
    576 
    577   llvm::Metadata *mdValue = mdNode->getOperand(0);
    578   if (mdValue == nullptr)
    579     return;
    580 
    581   if (getStringOperand(mdValue) == "no")
    582     mIsThreadable = false;
    583 }
    584 
    585 void MetadataExtractor::readBuildChecksumMetadata(
    586     const llvm::NamedMDNode *ChecksumMetadata) {
    587 
    588   if (ChecksumMetadata == nullptr)
    589     return;
    590 
    591   llvm::MDNode *mdNode = ChecksumMetadata->getOperand(0);
    592   if (mdNode == nullptr)
    593     return;
    594 
    595   llvm::Metadata *mdValue = mdNode->getOperand(0);
    596   if (mdValue == nullptr)
    597     return;
    598 
    599   mBuildChecksum = createStringFromValue(mdValue);
    600 }
    601 
    602 bool MetadataExtractor::extract() {
    603   if (!(mBitcode && mBitcodeSize) && !mModule) {
    604     ALOGE("Invalid/empty bitcode/module");
    605     return false;
    606   }
    607 
    608   std::unique_ptr<llvm::LLVMContext> mContext;
    609   bool shouldNullModule = false;
    610 
    611   if (!mModule) {
    612     mContext.reset(new llvm::LLVMContext());
    613     std::unique_ptr<llvm::MemoryBuffer> MEM(
    614       llvm::MemoryBuffer::getMemBuffer(
    615         llvm::StringRef(mBitcode, mBitcodeSize), "", false));
    616     std::string error;
    617 
    618     llvm::ErrorOr<std::unique_ptr<llvm::Module> > errval =
    619         llvm::parseBitcodeFile(MEM.get()->getMemBufferRef(), *mContext);
    620     if (std::error_code ec = errval.getError()) {
    621         ALOGE("Could not parse bitcode file");
    622         ALOGE("%s", ec.message().c_str());
    623         return false;
    624     }
    625 
    626     mModule = errval.get().release();
    627     shouldNullModule = true;
    628   }
    629 
    630   const llvm::NamedMDNode *ExportVarMetadata =
    631       mModule->getNamedMetadata(ExportVarMetadataName);
    632   const llvm::NamedMDNode *ExportFuncMetadata =
    633       mModule->getNamedMetadata(ExportFuncMetadataName);
    634   const llvm::NamedMDNode *ExportForEachNameMetadata =
    635       mModule->getNamedMetadata(ExportForEachNameMetadataName);
    636   const llvm::NamedMDNode *ExportForEachMetadata =
    637       mModule->getNamedMetadata(ExportForEachMetadataName);
    638   const llvm::NamedMDNode *ExportReduceMetadata =
    639       mModule->getNamedMetadata(ExportReduceMetadataName);
    640   const llvm::NamedMDNode *PragmaMetadata =
    641       mModule->getNamedMetadata(PragmaMetadataName);
    642   const llvm::NamedMDNode *ObjectSlotMetadata =
    643       mModule->getNamedMetadata(ObjectSlotMetadataName);
    644   const llvm::NamedMDNode *ThreadableMetadata =
    645       mModule->getNamedMetadata(ThreadableMetadataName);
    646   const llvm::NamedMDNode *ChecksumMetadata =
    647       mModule->getNamedMetadata(ChecksumMetadataName);
    648   const llvm::NamedMDNode *DebugInfoMetadata =
    649       mModule->getNamedMetadata(DebugInfoMetadataName);
    650 
    651   if (!populateNameMetadata(ExportVarMetadata, mExportVarNameList,
    652                             mExportVarCount)) {
    653     ALOGE("Could not populate export variable metadata");
    654     goto err;
    655   }
    656 
    657   if (!populateNameMetadata(ExportFuncMetadata, mExportFuncNameList,
    658                             mExportFuncCount)) {
    659     ALOGE("Could not populate export function metadata");
    660     goto err;
    661   }
    662 
    663   if (!populateForEachMetadata(ExportForEachNameMetadata,
    664                                ExportForEachMetadata)) {
    665     ALOGE("Could not populate ForEach signature metadata");
    666     goto err;
    667   }
    668 
    669   if (!populateReduceMetadata(ExportReduceMetadata)) {
    670     ALOGE("Could not populate export general reduction metadata");
    671     goto err;
    672   }
    673 
    674   populatePragmaMetadata(PragmaMetadata);
    675 
    676   if (!populateObjectSlotMetadata(ObjectSlotMetadata)) {
    677     ALOGE("Could not populate object slot metadata");
    678     goto err;
    679   }
    680 
    681   readThreadableFlag(ThreadableMetadata);
    682   readBuildChecksumMetadata(ChecksumMetadata);
    683 
    684   mHasDebugInfo = DebugInfoMetadata != nullptr;
    685 
    686   if (shouldNullModule) {
    687     mModule = nullptr;
    688   }
    689   return true;
    690 
    691 err:
    692   if (shouldNullModule) {
    693     mModule = nullptr;
    694   }
    695   return false;
    696 }
    697 
    698 }  // namespace bcinfo
    699