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 #ifndef __ANDROID_BCINFO_METADATAEXTRACTOR_H__
     18 #define __ANDROID_BCINFO_METADATAEXTRACTOR_H__
     19 
     20 #include <cstddef>
     21 #include <stdint.h>
     22 
     23 namespace llvm {
     24   class Module;
     25   class NamedMDNode;
     26 }
     27 
     28 namespace bcinfo {
     29 
     30 enum RSFloatPrecision {
     31   RS_FP_Full = 0,
     32   RS_FP_Relaxed = 1,
     33   RS_FP_Imprecise = 2
     34 };
     35 
     36 class MetadataExtractor {
     37  private:
     38   const llvm::Module *mModule;
     39   const char *mBitcode;
     40   size_t mBitcodeSize;
     41 
     42   size_t mExportVarCount;
     43   size_t mExportFuncCount;
     44   size_t mExportForEachSignatureCount;
     45   const char **mExportVarNameList;
     46   const char **mExportFuncNameList;
     47   const char **mExportForEachNameList;
     48   const uint32_t *mExportForEachSignatureList;
     49 
     50   size_t mPragmaCount;
     51   const char **mPragmaKeyList;
     52   const char **mPragmaValueList;
     53 
     54   size_t mObjectSlotCount;
     55   const uint32_t *mObjectSlotList;
     56 
     57   uint32_t mCompilerVersion;
     58   uint32_t mOptimizationLevel;
     59 
     60   enum RSFloatPrecision mRSFloatPrecision;
     61 
     62   // Helper functions for extraction
     63   bool populateVarNameMetadata(const llvm::NamedMDNode *VarNameMetadata);
     64   bool populateFuncNameMetadata(const llvm::NamedMDNode *FuncNameMetadata);
     65   bool populateForEachMetadata(const llvm::NamedMDNode *Names,
     66                                const llvm::NamedMDNode *Signatures);
     67   bool populateObjectSlotMetadata(const llvm::NamedMDNode *ObjectSlotMetadata);
     68   void populatePragmaMetadata(const llvm::NamedMDNode *PragmaMetadata);
     69 
     70  public:
     71   /**
     72    * Reads metadata from \p bitcode.
     73    *
     74    * \param bitcode - input bitcode string.
     75    * \param bitcodeSize - length of \p bitcode string (in bytes).
     76    */
     77   MetadataExtractor(const char *bitcode, size_t bitcodeSize);
     78 
     79   /**
     80    * Reads metadata from \p module.
     81    *
     82    * \param module - input module.
     83    */
     84   MetadataExtractor(const llvm::Module *module);
     85 
     86   ~MetadataExtractor();
     87 
     88   /**
     89    * Extract the actual metadata from the supplied bitcode.
     90    *
     91    * \return true on success and false if an error occurred.
     92    */
     93   bool extract();
     94 
     95   /**
     96    * \return number of exported global variables (slots) in this script/module.
     97    */
     98   size_t getExportVarCount() const {
     99     return mExportVarCount;
    100   }
    101 
    102   /**
    103    * \return array of exported variable names.
    104    */
    105   const char **getExportVarNameList() const {
    106     return mExportVarNameList;
    107   }
    108 
    109   /**
    110    * \return number of exported global functions (slots) in this script/module.
    111    */
    112   size_t getExportFuncCount() const {
    113     return mExportFuncCount;
    114   }
    115 
    116   /**
    117    * \return array of exported function names.
    118    */
    119   const char **getExportFuncNameList() const {
    120     return mExportFuncNameList;
    121   }
    122 
    123   /**
    124    * \return number of exported ForEach functions in this script/module.
    125    */
    126   size_t getExportForEachSignatureCount() const {
    127     return mExportForEachSignatureCount;
    128   }
    129 
    130   /**
    131    * \return array of exported ForEach function signatures.
    132    */
    133   const uint32_t *getExportForEachSignatureList() const {
    134     return mExportForEachSignatureList;
    135   }
    136 
    137   /**
    138    * \return array of exported ForEach function names.
    139    */
    140   const char **getExportForEachNameList() const {
    141     return mExportForEachNameList;
    142   }
    143 
    144   /**
    145    * \return number of pragmas contained in pragmaKeyList and pragmaValueList.
    146    */
    147   size_t getPragmaCount() const {
    148     return mPragmaCount;
    149   }
    150 
    151   /**
    152    * \return pragma keys (the name for the pragma).
    153    */
    154   const char **getPragmaKeyList() const {
    155     return mPragmaKeyList;
    156   }
    157 
    158   /**
    159    * \return pragma values (contents corresponding to a particular pragma key).
    160    */
    161   const char **getPragmaValueList() const {
    162     return mPragmaValueList;
    163   }
    164 
    165   /**
    166    * \return number of object slots contained in objectSlotList.
    167    */
    168   size_t getObjectSlotCount() const {
    169     return mObjectSlotCount;
    170   }
    171 
    172   /**
    173    * \return array of object slot numbers that must be cleaned up by driver
    174    *         on script teardown.
    175    */
    176   const uint32_t *getObjectSlotList() const {
    177     return mObjectSlotList;
    178   }
    179 
    180   /**
    181    * \return compiler version that generated this bitcode.
    182    */
    183   uint32_t getCompilerVersion() const {
    184     return mCompilerVersion;
    185   }
    186 
    187   /**
    188    * \return compiler optimization level for this bitcode.
    189    */
    190   uint32_t getOptimizationLevel() const {
    191     return mOptimizationLevel;
    192   }
    193 
    194   /**
    195    * \return minimal floating point precision that the script requires.
    196    */
    197   enum RSFloatPrecision getRSFloatPrecision() const {
    198     return mRSFloatPrecision;
    199   }
    200 
    201   /**
    202    * \return whether or not this ForEach function signature has an "In"
    203    * parameter.
    204    *
    205    * \param sig - ForEach function signature to check.
    206    */
    207   static bool hasForEachSignatureIn(uint32_t sig) {
    208     return sig & 0x01;
    209   }
    210 
    211   /**
    212    * \return whether or not this ForEach function signature has an "Out"
    213    * parameter.
    214    *
    215    * \param sig - ForEach function signature to check.
    216    */
    217   static bool hasForEachSignatureOut(uint32_t sig) {
    218     return sig & 0x02;
    219   }
    220 
    221   /**
    222    * \return whether or not this ForEach function signature has a "UsrData"
    223    * parameter.
    224    *
    225    * \param sig - ForEach function signature to check.
    226    */
    227   static bool hasForEachSignatureUsrData(uint32_t sig) {
    228     return sig & 0x04;
    229   }
    230 
    231   /**
    232    * \return whether or not this ForEach function signature has an "X"
    233    * parameter.
    234    *
    235    * \param sig - ForEach function signature to check.
    236    */
    237   static bool hasForEachSignatureX(uint32_t sig) {
    238     return sig & 0x08;
    239   }
    240 
    241   /**
    242    * \return whether or not this ForEach function signature has a "Y"
    243    * parameter.
    244    *
    245    * \param sig - ForEach function signature to check.
    246    */
    247   static bool hasForEachSignatureY(uint32_t sig) {
    248     return sig & 0x10;
    249   }
    250 
    251   /**
    252    * \return whether or not this ForEach function signature is a
    253    * pass-by-value "Kernel".
    254    *
    255    * \param sig - ForEach function signature to check.
    256    */
    257   static bool hasForEachSignatureKernel(uint32_t sig) {
    258     return sig & 0x20;
    259   }
    260 };
    261 
    262 }  // namespace bcinfo
    263 
    264 #endif  // __ANDROID_BCINFO_METADATAEXTRACTOR_H__
    265