[PATCH 6/8] keyctl: Add support for KEYCTL_DH_COMPUTE
Eugene Syromyatnikov
evgsyr at gmail.com
Thu Sep 29 12:57:27 UTC 2016
* keyctl.c (struct keyctl_dh_params): New structure.
(print_dh_params): New function.
(keyctl_dh_compute): New function.
(SYS_FUNC(keyctl)): Add support for KEYCTL_DH_COMPUTE cmd value.
---
keyctl.c | 46 ++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 46 insertions(+)
diff --git a/keyctl.c b/keyctl.c
index 1fb1da5..0a9953e 100644
--- a/keyctl.c
+++ b/keyctl.c
@@ -31,6 +31,12 @@ typedef int32_t key_serial_t;
#include "xlat/key_spec.h"
+struct keyctl_dh_params {
+ int32_t private;
+ int32_t prime;
+ int32_t base;
+};
+
static void
print_keyring_serial_number(key_serial_t id)
{
@@ -213,6 +219,41 @@ keyctl_setperm_key(struct tcb *tcp, key_serial_t id, uint32_t perm)
printflags(key_perms, perm, "KEY_???");
}
+static void
+print_dh_params(struct tcb *tcp, long addr)
+{
+ struct keyctl_dh_params params;
+
+ if (umove_or_printaddr(tcp, addr, ¶ms))
+ return;
+
+ tprints("{private=");
+ print_keyring_serial_number(params.private);
+ tprints(", prime=");
+ print_keyring_serial_number(params.prime);
+ tprints(", base=");
+ print_keyring_serial_number(params.base);
+ tprints("}");
+}
+
+static void
+keyctl_dh_compute(struct tcb *tcp, long params, long buf, long len)
+{
+ if (entering(tcp)) {
+ print_dh_params(tcp, params);
+ tprints(", ");
+ } else {
+ if (syserror(tcp))
+ printaddr(buf);
+ else {
+ long rval = tcp->u_rval > len ?
+ len : (tcp->u_rval ? -1 : 0);
+ printstr(tcp, buf, rval);
+ }
+ tprintf(", %lu", len);
+ }
+}
+
#include "xlat/key_reqkeys.h"
#include "xlat/keyctl_commands.h"
@@ -314,6 +355,11 @@ SYS_FUNC(keyctl)
keyctl_get_persistent(tcp, tcp->u_arg[1], tcp->u_arg[2]);
break;
+ case KEYCTL_DH_COMPUTE:
+ keyctl_dh_compute(tcp, tcp->u_arg[1], tcp->u_arg[2],
+ tcp->u_arg[3]);
+ return 0;
+
default:
tprintf("%#llx, %#llx, %#llx, %#llx",
getarg_ull(tcp, 1), getarg_ull(tcp, 2),
--
1.7.10.4
More information about the Strace-devel
mailing list