-
Notifications
You must be signed in to change notification settings - Fork 241
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Tee client api errata #362
Tee client api errata #362
Conversation
6afc2ac
to
4fbd0ba
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed-by: Etienne Carriere <[email protected]>
for commit
"tee_client_api: correct reference to TEEC_MemoryReference".
Reviewed-by: Etienne Carriere <[email protected]>
for commit
"tee_client_api: define additional return codes" once comments are addressed.
@@ -186,6 +197,15 @@ extern "C" { | |||
#define TEEC_ERROR_EXTERNAL_CANCEL 0xFFFF0011 | |||
#define TEEC_ERROR_TARGET_DEAD 0xFFFF3024 | |||
#define TEEC_ERROR_STORAGE_NO_SPACE 0xFFFF3041 | |||
#define TEE_ERROR_EXTERNAL_CANCEL 0xFFFF0011 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please move this line right above line 197.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
My preference would have been to keep the order the same as it appears in Global Platform specification. But I do not want to argue on that. I applied your suggestion in cb92e7f.
#define TEE_ERROR_EXTERNAL_CANCEL 0xFFFF0011 | ||
#define TEE_ERROR_OVERFLOW 0xFFFF300F | ||
#define TEE_ERROR_TARGET_DEAD 0xFFFF3024 | ||
#define TEEC_ERROR_TARGET_DEAD 0xFFFF3024 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please move TEE_ERROR_TARGET_DEAD
definition right above line 198 and remove below line.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for spotting the duplicate. Fixed in cb92e7f.
#define TEE_ERROR_OVERFLOW 0xFFFF300F | ||
#define TEE_ERROR_TARGET_DEAD 0xFFFF3024 | ||
#define TEEC_ERROR_TARGET_DEAD 0xFFFF3024 | ||
#define TEE_ERROR_STORAGE_NO_SPACE 0xFFFF3041 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
prefer TEE_ERROR_STORAGE_NO_SPACE
definition right above TEEC_ERROR_STORAGE_NO_SPACE
definition.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same comment as above. I applied the suggestion in cb92e7f.
Apply the errata from [1] which fixes two typos in the definition of the paramTypes. [1] TEE Client API Specification v1.0 Errata and Precisions Version 2.0, §E.1 Correct Reference to TEEC_MemoryReference Signed-off-by: Vincent Mailhol <[email protected]> Reviewed-by: Etienne Carriere <[email protected]>
4fbd0ba
to
cb92e7f
Compare
Done
Done but I rewrote the description to explain the reordering. Thanks for your confirmation. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One last change in commit "tee_client_api: define additional return codes" and I'm fine with the series.
libteec/include/tee_client_api.h
Outdated
#define TEEC_ERROR_STORAGE_NO_SPACE 0xFFFF3041 | ||
#define TEE_ERROR_OVERFLOW 0xFFFF300F |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To meet value ordering:
(...)
#define TEEC_ERROR_EXTERNAL_CANCEL 0xFFFF0011
+#define TEE_ERROR_OVERFLOW 0xFFFF300F
#define TEE_ERROR_TARGET_DEAD 0xFFFF3024
#define TEEC_ERROR_TARGET_DEAD 0xFFFF3024
#define TEE_ERROR_STORAGE_NO_SPACE 0xFFFF3041
-#define TEE_ERROR_OVERFLOW 0xFFFF300F
#define TEE_ERROR_MAC_INVALID 0xFFFF3071
(...)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Applied in a9cfb99. I also reorder the entry in the documentation and amended the commit description accordingly.
The precision from [1] defines 9 additional return codes. One of them, TEEC_ERROR_TARGET_DEAD was already added in [2]. Apply the 8 other ones and reorder them by values. The added documentation is a verbatim copy of the description from [1]. Overwrite the existing documentation of TEEC_ERROR_TARGET_DEAD with the one from the specification. [1] TEE Client API Specification v1.0 Errata and Precisions Version 2.0, §P.4 Define Additional Return Codes [2] commit f2b0ed4 ("Updated related Linux Driver Refactoring") Link: OP-TEE@f2b0ed41c8c7b3 Signed-off-by: Vincent Mailhol <[email protected]> Reviewed-by: Etienne Carriere <[email protected]>
cb92e7f
to
6f76f14
Compare
For what it is worth: I added 6f76f14 to deprecate |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Acked-by: Etienne Carriere <[email protected]>
for commit
"tee_client_api: deprecate two TEE_ERROR_* macros not in the specification".
…tion TEE_ERROR_EXTERNAL_CANCEL and TEE_ERROR_STORAGE_NO_SPACE are not part of the specification [1]. TEEC_ERROR_EXTERNAL_CANCEL and TEEC_ERROR_STORAGE_NO_SPACE should be preferred instead. Add a message in the description to deprecate these two macros, but keep them for backward compatibility. [1] TEE Client API Specification v1.0 Errata and Precisions Version 2.0, §P.4 Define Additional Return Codes Signed-off-by: Vincent Mailhol <[email protected]> Acked-by: Etienne Carriere <[email protected]>
6f76f14
to
8125349
Compare
This pull request has been marked as a stale pull request because it has been open (more than) 30 days with no activity. Remove the stale label or add a comment, otherwise this pull request will automatically be closed in 5 days. Note, that you can always re-open a closed issue at any time. |
I think this P-R is ready to be merged. @jenswi-linaro, @jforissier, any comment on these changes? |
It is. Thanks. |
Global Platform published the TEE Client API Specification v1.0 Errata and Precisions Version 2.0 in 2014. This document is not yet reflected in optee_client.
The document contains two errata:
TEEC_MemoryReference
TEEC_PARAMS_TYPE
and four precisions:
The first patch of this series covers errata E.1, the second patch covers precision P.4. The third and last patch deprecates two existing return codes and suggest to use instead the ones introduced in precision P.4.
The remaining errata E.2 and precision P.1 to P.3 do not impact the implementation.