X-Git-Url: https://git.openssl.org/gitweb/?p=openssl.git;a=blobdiff_plain;f=engines%2Fafalg%2Fe_afalg.c;h=2ea5ba5232a1996ba09e1ee7c3ba773cde543264;hp=1766230ce8f664be13920dae1f54c379e25e5f23;hb=40c60b0d7389aa479cf7474a080737e901944d0d;hpb=e7e5d608fb6cef9929a2cf56d72fa7e236ca7573 diff --git a/engines/afalg/e_afalg.c b/engines/afalg/e_afalg.c index 1766230ce8..2ea5ba5232 100644 --- a/engines/afalg/e_afalg.c +++ b/engines/afalg/e_afalg.c @@ -230,11 +230,15 @@ int afalg_fin_cipher_aio(afalg_aio *aio, int sfd, unsigned char *buf, memset(cb, '\0', sizeof(*cb)); cb->aio_fildes = sfd; cb->aio_lio_opcode = IOCB_CMD_PREAD; - /* - * The pointer has to be converted to unsigned value first to avoid - * sign extension on cast to 64 bit value - */ - cb->aio_buf = (uint64_t)(unsigned long)buf; + if (sizeof(buf) != sizeof(cb->aio_buf)) { + /* + * The pointer has to be converted to 32 bit unsigned value first + * to avoid sign extension on cast to 64 bit value + */ + cb->aio_buf = (uint64_t)(unsigned long)buf; + } else { + cb->aio_buf = (uint64_t)buf; + } cb->aio_offset = 0; cb->aio_data = 0; cb->aio_nbytes = len;