fix(tvix/eval/benches): use black_box properly

The purpose of black_box is to actually prevent the compiler from being
able to optimize computation of the benchmarked function away.

To accomplish this, we need to actually *use* black_box to blackbox the
input data away, rather than the return type.

Change-Id: I5438982f57509fbf7b85034346a2739d76aef1fa
Reviewed-on: https://cl.tvl.fyi/c/depot/+/9902
Autosubmit: flokli <flokli@flokli.de>
Reviewed-by: tazjin <tazjin@tvl.su>
Tested-by: BuildkiteCI
This commit is contained in:
Florian Klink 2023-11-02 22:28:26 +02:00 committed by flokli
parent 524acf0337
commit 1571d7195e

View file

@ -8,8 +8,7 @@ fn interpret(code: &str) {
fn eval_literals(c: &mut Criterion) { fn eval_literals(c: &mut Criterion) {
c.bench_function("int", |b| { c.bench_function("int", |b| {
b.iter(|| { b.iter(|| {
interpret("42"); interpret(black_box("42"));
black_box(())
}) })
}); });
} }
@ -17,8 +16,7 @@ fn eval_literals(c: &mut Criterion) {
fn eval_merge_attrs(c: &mut Criterion) { fn eval_merge_attrs(c: &mut Criterion) {
c.bench_function("merge small attrs", |b| { c.bench_function("merge small attrs", |b| {
b.iter(|| { b.iter(|| {
interpret("{ a = 1; b = 2; } // { c = 3; }"); interpret(black_box("{ a = 1; b = 2; } // { c = 3; }"));
black_box(())
}) })
}); });
@ -29,8 +27,7 @@ fn eval_merge_attrs(c: &mut Criterion) {
); );
let expr = format!("{large_attrs} // {{ c = 3; }}"); let expr = format!("{large_attrs} // {{ c = 3; }}");
b.iter(move || { b.iter(move || {
interpret(&expr); interpret(black_box(&expr));
black_box(())
}) })
}); });
} }