44#define SSE_FUNC_PROCESS(LLVM_NAME ,FUNC_NAME) \ 
   45        auto sse_##FUNC_NAME = [this](const CallICFGNode *callNode) { \ 
   47        AbstractState& as = getAbsStateFromTrace(callNode); \ 
   48        u32_t rhs_id = callNode->getArgument(0)->getId(); \ 
   49        if (!as.inVarToValTable(rhs_id)) return; \ 
   50        u32_t rhs = as[rhs_id].getInterval().lb().getIntNumeral(); \ 
   51        s32_t res = FUNC_NAME(rhs);            \ 
   52        u32_t lhsId = callNode->getRetICFGNode()->getActualRet()->getId();               \ 
   53        as[lhsId] = IntervalValue(res);           \ 
   56    func_map[#FUNC_NAME] = sse_##FUNC_NAME; 
  100        if (
as[
arg0].getInterval().equals(
as[
arg1].getInterval()))
 
  115        if (
callNode->arg_size() < 2) 
return;
 
  119        assert(
as.inVarToValTable(
num_id) && 
"print() should pass integer");
 
  122                  << 
", PrintVal: " << 
itv.toString() << 
", Loc:" << 
callNode->getSourceLoc() << std::endl;
 
  129        if (
callNode->arg_size() < 2) 
return;
 
  135        num.getInterval().set_to_top();
 
  137        const ICFGNode* node = SVFUtil::cast<ValVar>(
callNode->getArgument(0))->getICFGNode();
 
  140            if (SVFUtil::isa<LoadStmt>(
stmt))
 
  155        if (
callNode->arg_size() < 2) 
return;
 
  176        if (
callNode->arg_size() < 3) 
return;
 
  205        if (
callNode->arg_size() < 3) 
return;
 
  222        if (
callNode->arg_size() < 2) 
return;
 
  228        if (
callNode->getArgument(2)->getType()->isArrayTy())
 
  230            elemSize = SVFUtil::dyn_cast<SVFArrayType>(
 
  231                           callNode->getArgument(2)->getType())->getTypeOfElement()->getByteSize();
 
  233        else if (
callNode->getArgument(2)->getType()->isPointerTy())
 
  263        if (
callNode->arg_size() < 3) 
return;
 
  268        std::string 
snum = std::to_string(
num);
 
  276        if (
callNode->arg_size() < 1) 
return;
 
  303        if (
as.inVarToAddrsTable(
dstid))
 
  314                if (
val.getInterval().is_numeral() && (
char) 
val.getInterval().getIntNumeral() == 
'\0')
 
  336        if (
callNode->arg_size() < 4) 
return;
 
  348        if (
callNode->arg_size() < 1) 
return;
 
  367        "VOS_MemFree", 
"cfree", 
"free", 
"free_all_mem", 
"freeaddrinfo",
 
  368        "gcry_mpi_release", 
"gcry_sexp_release", 
"globfree", 
"nhfree",
 
  369        "obstack_free", 
"safe_cfree", 
"safe_free", 
"safefree", 
"safexfree",
 
  370        "sm_free", 
"vim_free", 
"xfree", 
"SSL_CTX_free", 
"SSL_free", 
"XFree" 
 
  383        assert(0 && 
"No preAbsTrace for this node");
 
 
  400        if (!
as.inVarToAddrsTable(
rhs->getId())) 
continue;
 
  409        if (!
val.getInterval().is_numeral())
 
  413        if ((
char) 
val.getInterval().getIntNumeral() == 
'\0')
 
  417        str0.push_back((
char) 
val.getInterval().getIntNumeral());
 
 
  426    assert(fun && 
"FunObjVar* is nullptr");
 
  431        if (
annotation.find(
"MEMCPY") != std::string::npos)
 
  433        if (
annotation.find(
"MEMSET") != std::string::npos)
 
  435        if (
annotation.find(
"STRCPY") != std::string::npos)
 
  437        if (
annotation.find(
"STRCAT") != std::string::npos)
 
  451                if (
as.inVarToAddrsTable(
lhsId))
 
 
  540            if (
val.getInterval().is_numeral() && (
char) 
val.getInterval().getIntNumeral() == 
'\0')
 
  546        if (
strValue->getType()->isArrayTy())
 
  548            elemSize = SVFUtil::dyn_cast<SVFArrayType>(
strValue->getType())->getTypeOfElement()->getByteSize();
 
  550        else if (
strValue->getType()->isPointerTy())
 
  555                    elemSize = SVFUtil::dyn_cast<SVFArrayType>(
elemType)->getTypeOfElement()->getByteSize();
 
  566            assert(
false && 
"we cannot support this type");
 
 
  586    const std::vector<std::string> 
strcatGroup = {
"__strcat_chk", 
"strcat", 
"__wcscat_chk", 
"wcscat"};
 
  587    const std::vector<std::string> 
strncatGroup = {
"__strncat_chk", 
"strncat", 
"__wcsncat_chk", 
"wcsncat"};
 
  611        assert(
false && 
"unknown strcat function, please add it to strcatGroup or strncatGroup");
 
 
  622        elemSize = SVFUtil::dyn_cast<SVFArrayType>(dst->
getType())->getTypeOfElement()->getByteSize();
 
  630                elemSize = SVFUtil::dyn_cast<SVFArrayType>(
elemType)->getTypeOfElement()->getByteSize();
 
  641        assert(
false && 
"we cannot support this type");
 
  654            for (
const auto &dst: 
expr_dst.getAddrs())
 
  656                for (
const auto &src: 
expr_src.getAddrs())
 
  659                    if (
as.inAddrToValTable(
objId))
 
  661                        as.store(dst, 
as.load(src));
 
  663                    else if (
as.inAddrToAddrsTable(
objId))
 
  665                        as.store(dst, 
as.load(src));
 
 
  680        elemSize = SVFUtil::dyn_cast<SVFArrayType>(dst->
getType())->getTypeOfElement()->getByteSize();
 
  695        assert(
false && 
"we cannot support this type");
 
  702        if (
as.inVarToAddrsTable(
dstId))
 
  708                if (
as.inAddrToValTable(
objId))
 
 
  747                ub = 
static_cast<s64_t>(std::numeric_limits<s32_t>::max());
 
  748                lb = 
static_cast<s64_t>(std::numeric_limits<s32_t>::min());
 
  752                ub = 
static_cast<s64_t>(std::numeric_limits<u32_t>::max());
 
  753                lb = 
static_cast<s64_t>(std::numeric_limits<u32_t>::min());
 
  760                ub = 
static_cast<s64_t>(std::numeric_limits<s16_t>::max());
 
  761                lb = 
static_cast<s64_t>(std::numeric_limits<s16_t>::min());
 
  765                ub = 
static_cast<s64_t>(std::numeric_limits<u16_t>::max());
 
  766                lb = 
static_cast<s64_t>(std::numeric_limits<u16_t>::min());
 
  773                ub = 
static_cast<s64_t>(std::numeric_limits<int8_t>::max());
 
  774                lb = 
static_cast<s64_t>(std::numeric_limits<int8_t>::min());
 
  778                ub = 
static_cast<s64_t>(std::numeric_limits<uint8_t>::max());
 
  779                lb = 
static_cast<s64_t>(std::numeric_limits<uint8_t>::min());
 
  784    else if (SVFUtil::isa<SVFOtherType>(
type))
 
  787        s64_t ub = 
static_cast<s64_t>(std::numeric_limits<s32_t>::max());
 
  788        s64_t lb = 
static_cast<s64_t>(std::numeric_limits<s32_t>::min());
 
 
#define SSE_FUNC_PROCESS(LLVM_NAME,FUNC_NAME)
std::string strRead(AbstractState &as, const SVFVar *rhs)
Reads a string from the abstract state.
void handleMemset(AbstractState &as, const SVFVar *dst, IntervalValue elem, IntervalValue len)
Handles the memset API call.
void initExtFunMap()
Initializes the external function map.
IntervalValue getStrlen(AbstractState &as, const SVF::SVFVar *strValue)
Calculates the length of a string.
Map< const ICFGNode *, AbstractState > & abstractTrace
Map of ICFG nodes to abstract states.
void handleExtAPI(const CallICFGNode *call)
Handles an external API call.
AbsExtAPI(Map< const ICFGNode *, AbstractState > &traces)
Constructor for AbsExtAPI.
AbstractState & getAbsStateFromTrace(const ICFGNode *node)
Retrieves the abstract state from the trace for a given ICFG node.
void handleMemcpy(AbstractState &as, const SVF::SVFVar *dst, const SVF::SVFVar *src, IntervalValue len, u32_t start_idx)
Handles the memcpy API call.
SVFIR * svfir
Pointer to the SVF intermediate representation.
void handleStrcat(const SVF::CallICFGNode *call)
Handles the strcat API call.
ExtAPIType
Enumeration of external API types.
IntervalValue getRangeLimitFromType(const SVFType *type)
Gets the range limit from a type.
ICFG * icfg
Pointer to the interprocedural control flow graph.
void handleStrcpy(const CallICFGNode *call)
Handles the strcpy API call.
Map< std::string, std::function< void(const CallICFGNode *)> > func_map
Map of function names to handlers.
static AbstractInterpretation & getAEInstance()
Set< const CallICFGNode * > checkpoints
static bool isInvalidMem(u32_t addr)
void join_with(const AbstractValue &other)
IntervalValue & getInterval()
NodeID getRHSVarID() const
const ICFGNode * getICFGNode() const
Get the ICFGNode related to the creation of this object.
bool isConstantByteSize() const
Check if byte size is a const value.
u32_t getByteSizeOfObj() const
Get the byte size of this object.
const ValVar * getArgument(u32_t ArgNo) const
Parameter operations.
const FunObjVar * getCalledFunction() const
const RetICFGNode * getRetICFGNode() const
Return callsite.
static ExtAPI * getExtAPI()
const std::vector< std::string > & getExtFuncAnnotations(const FunObjVar *fun)
NodeType * getGNode(NodeID id) const
Get a node.
const SVFStmtList & getSVFStmts() const
const BoundedInt & ub() const
Return the upper bound.
bool is_numeral() const
Return true if the IntervalValue is a number [num, num].
const std::string toString() const
static IntervalValue top()
Create the IntervalValue [-inf, +inf].
const BoundedInt & lb() const
Return the lower bound.
static const Option< u32_t > MaxFieldLimit
Maximum number of field derivations for an object.
const SVFVar * getActualRet() const
Return actual return parameter.
const BaseObjVar * getBaseObject(NodeID id) const
static SVFIR * getPAG(bool buildFromFile=false)
Singleton design here to make sure we only have one instance during any analysis.
NodeID getId() const
Get ID.
virtual const SVFType * getType() const
virtual const std::string & getName() const
int ispunct(int argument)
int isblank(int character)
int isalnum(int character)
int isalpha(int character)
std::string sucMsg(const std::string &msg)
Returns successful message by converting a string into green string output.
std::string errMsg(const std::string &msg)
Print error message by converting a string into red string output.
std::ostream & errs()
Overwrite llvm::errs()
llvm::IRBuilder IRBuilder