aboutsummaryrefslogtreecommitdiff
path: root/src/tls/sha_drv.c
diff options
context:
space:
mode:
authorBadlop <badlop@process-one.net>2011-12-21 12:15:21 +0100
committerBadlop <badlop@process-one.net>2011-12-21 12:15:21 +0100
commit2029e39299aebe3c4882a26294f4caadc8881265 (patch)
tree1e4b7391dbd3dcc42b21f64ffdae7a721e047dd7 /src/tls/sha_drv.c
parentReplace regexp with ejabberd_regexp (diff)
Support Erlang/OTP R15B driver (EJAB-1521)
Diffstat (limited to 'src/tls/sha_drv.c')
-rw-r--r--src/tls/sha_drv.c30
1 files changed, 26 insertions, 4 deletions
diff --git a/src/tls/sha_drv.c b/src/tls/sha_drv.c
index 22426703f..fc8fb9a49 100644
--- a/src/tls/sha_drv.c
+++ b/src/tls/sha_drv.c
@@ -24,16 +24,26 @@
#include <openssl/md2.h>
#endif
+/*
+ * R15B changed several driver callbacks to use ErlDrvSizeT and
+ * ErlDrvSSizeT typedefs instead of int.
+ * This provides missing typedefs on older OTP versions.
+ */
+#if ERL_DRV_EXTENDED_MAJOR_VERSION < 2
+typedef int ErlDrvSizeT;
+typedef int ErlDrvSSizeT;
+#endif
+
static ErlDrvData sha_drv_start(ErlDrvPort port, char *buf)
{
set_port_control_flags(port, PORT_CONTROL_FLAG_BINARY);
return NULL;
}
-static int sha_drv_control(ErlDrvData handle,
+static ErlDrvSSizeT sha_drv_control(ErlDrvData handle,
unsigned int command,
- char *buf, int len,
- char **rbuf, int rlen)
+ char *buf, ErlDrvSizeT len,
+ char **rbuf, ErlDrvSizeT rlen)
{
ErlDrvBinary *b = NULL;
@@ -89,7 +99,19 @@ ErlDrvEntry sha_driver_entry = {
NULL, /* handle */
sha_drv_control, /* F_PTR control, port_command callback */
NULL, /* F_PTR timeout, reserved */
- NULL /* F_PTR outputv, reserved */
+ NULL, /* F_PTR outputv, reserved */
+ /* Added in Erlang/OTP R15B: */
+ NULL, /* ready_async */
+ NULL, /* flush */
+ NULL, /* call */
+ NULL, /* event */
+ ERL_DRV_EXTENDED_MARKER, /* extended_marker */
+ ERL_DRV_EXTENDED_MAJOR_VERSION, /* major_version */
+ ERL_DRV_EXTENDED_MINOR_VERSION, /* minor_version */
+ 0, /* driver_flags */
+ NULL, /* handle2 */
+ NULL, /* process_exit */
+ NULL /* stop_select */
};
DRIVER_INIT(sha_drv) /* must match name in driver_entry */