ret = 1;
if (!strncmp(vp->ival, ptr, strlen(vp->ival))) {
ret = 0;
- if (!o->off1)
- break;
- val_store(ilp, vp->oval, o->off1, data);
+ if (o->roff1)
+ *(unsigned int *) o->roff1 = vp->oval;
+ else {
+ if (!o->off1)
+ break;
+ val_store(ilp, vp->oval, o->off1, data);
+ }
break;
}
}
ret = fn(data, &ull);
else {
if (o->type == FIO_OPT_INT) {
- if (first)
- val_store(ilp, ull, o->off1, data);
- if (!more && o->off2)
- val_store(ilp, ull, o->off2, data);
+ if (first) {
+ if (o->roff1)
+ *(unsigned long long *) o->roff1 = ull;
+ else
+ val_store(ilp, ull, o->off1, data);
+ }
+ if (!more) {
+ if (o->roff2)
+ *(unsigned long long *) o->roff2 = ull;
+ else if (o->off2)
+ val_store(ilp, ull, o->off2, data);
+ }
} else {
- if (first)
- val_store(ullp, ull, o->off1, data);
- if (!more && o->off2)
- val_store(ullp, ull, o->off2, data);
+ if (first) {
+ if (o->roff1)
+ *(unsigned long long *) o->roff1 = ull;
+ else
+ val_store(ullp, ull, o->off1, data);
+ }
+ if (!more) {
+ if (o->roff2)
+ *(unsigned long long *) o->roff2 = ull;
+ else if (o->off2)
+ val_store(ullp, ull, o->off2, data);
+ }
}
}
break;
case FIO_OPT_STR_STORE: {
fio_opt_str_fn *fn = o->cb;
- cp = td_var(data, o->off1);
+ if (o->roff1)
+ cp = (char **) o->roff1;
+ else
+ cp = td_var(data, o->off1);
+
*cp = strdup(ptr);
if (fn) {
ret = fn(data, ptr);
}
if (first) {
- val_store(ilp, ul1, o->off1, data);
- val_store(ilp, ul2, o->off2, data);
+ if (o->roff1)
+ *(unsigned long *) o->roff1 = ul1;
+ else
+ val_store(ilp, ul1, o->off1, data);
+ if (o->roff2)
+ *(unsigned long *) o->roff2 = ul2;
+ else
+ val_store(ilp, ul2, o->off2, data);
}
- if (o->off3 && o->off4) {
+ if (o->roff3 && o->roff4) {
+ *(unsigned long *) o->roff3 = ul1;
+ *(unsigned long *) o->roff4 = ul2;
+ } else if (o->off3 && o->off4) {
val_store(ilp, ul1, o->off3, data);
val_store(ilp, ul2, o->off4, data);
}
if (fn)
ret = fn(data, &il);
else {
- if (first)
- val_store(ilp, il, o->off1, data);
- if (!more && o->off2)
- val_store(ilp, il, o->off2, data);
+ if (first) {
+ if (o->roff1)
+ *(unsigned int *)o->roff1 = il;
+ else
+ val_store(ilp, il, o->off1, data);
+ }
+ if (!more) {
+ if (o->roff2)
+ *(unsigned int *) o->roff2 = il;
+ else if (o->off2)
+ val_store(ilp, il, o->off2, data);
+ }
}
break;
}
if (fn)
ret = fn(data);
else {
- if (first)
- val_store(ilp, 1, o->off1, data);
- if (!more && o->off2)
- val_store(ilp, 1, o->off2, data);
+ if (first) {
+ if (o->roff1)
+ *(unsigned int *) o->roff1 = 1;
+ else
+ val_store(ilp, 1, o->off1, data);
+ }
+ if (!more) {
+ if (o->roff2)
+ *(unsigned int *) o->roff2 = 1;
+ else if (o->off2)
+ val_store(ilp, 1, o->off2, data);
+ }
}
break;
}