Commit a6d7e3af authored by Yonghong Song's avatar Yonghong Song

prevent array subscript expression if base/index is not rewritable

The following command failed:
  trace.py -U 'r::_do_fork (retval == -11) "%llu", ((struct task_struct *)bpf_get_current_task())->signal->rlim[RLIMIT_NPROC].rlim_cur'

as rewriter generates code like
  __data.v0 = (unsigned long long)((struct task_struct *)bpf_get_current_task())->signal->rlim[RLIMIT_NPROC))); _val; }).rlim_cur;

Let us prevent rewriting if either base or index is not rewritable and this fixed the issue.
Signed-off-by: default avatarYonghong Song <yhs@fb.com>
parent c7ccd5b7
...@@ -505,6 +505,12 @@ bool ProbeVisitor::VisitArraySubscriptExpr(ArraySubscriptExpr *E) { ...@@ -505,6 +505,12 @@ bool ProbeVisitor::VisitArraySubscriptExpr(ArraySubscriptExpr *E) {
Expr *idx = E->getIdx(); Expr *idx = E->getIdx();
memb_visited_.insert(E); memb_visited_.insert(E);
if (!rewriter_.isRewritable(GET_BEGINLOC(base)))
return true;
if (!rewriter_.isRewritable(GET_BEGINLOC(idx)))
return true;
string pre, lbracket, rbracket; string pre, lbracket, rbracket;
LangOptions opts; LangOptions opts;
SourceLocation lbracket_start, lbracket_end; SourceLocation lbracket_start, lbracket_end;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment