Hi Jarkko,
On 5/26/2021 5:47 AM, Jarkko Sakkinen wrote:
...
- exit(KSFT_PASS);
+static inline int encl_call(const void *in, void *out, struct sgx_enclave_run *run, bool clobbered) +{
- void *in2 = (void *)in;
- int ret;
-err:
- encl_delete(&encl);
- exit(KSFT_FAIL);
- if (clobbered)
ret = vdso_sgx_enter_enclave((unsigned long)in2, (unsigned long)out, 0,
EENTER, 0, 0, run);
- else
ret = sgx_enter_enclave(in2, out, 0, EENTER, NULL, NULL, run);
- return ret;
+}
I find this change unnecessary because it is very specific to the current test cases and limiting future test cases. From what I understand it attempts to create a generic "call into the enclave" wrapper but in doing so it constrains the call to use only two registers, assuming there will always and only be just an "in" and "out" parameter needed.
Reinette