xref: /freebsd/crypto/openssl/crypto/mips_arch.h (revision b077aed3)
1e71b7053SJung-uk Kim /*
2*b077aed3SPierre Pronchery  * Copyright 2011-2016 The OpenSSL Project Authors. All Rights Reserved.
3e71b7053SJung-uk Kim  *
4*b077aed3SPierre Pronchery  * Licensed under the Apache License 2.0 (the "License").  You may not use
5e71b7053SJung-uk Kim  * this file except in compliance with the License.  You can obtain a copy
6e71b7053SJung-uk Kim  * in the file LICENSE in the source distribution or at
7e71b7053SJung-uk Kim  * https://www.openssl.org/source/license.html
8e71b7053SJung-uk Kim  */
9e71b7053SJung-uk Kim 
1017f01e99SJung-uk Kim #ifndef OSSL_CRYPTO_MIPS_ARCH_H
1117f01e99SJung-uk Kim # define OSSL_CRYPTO_MIPS_ARCH_H
12e71b7053SJung-uk Kim 
13e71b7053SJung-uk Kim # if (defined(__mips_smartmips) || defined(_MIPS_ARCH_MIPS32R3) || \
14610a21fdSJung-uk Kim       defined(_MIPS_ARCH_MIPS32R5) || defined(_MIPS_ARCH_MIPS32R6)) \
15e71b7053SJung-uk Kim       && !defined(_MIPS_ARCH_MIPS32R2)
16e71b7053SJung-uk Kim #  define _MIPS_ARCH_MIPS32R2
17e71b7053SJung-uk Kim # endif
18e71b7053SJung-uk Kim 
19e71b7053SJung-uk Kim # if (defined(_MIPS_ARCH_MIPS64R3) || defined(_MIPS_ARCH_MIPS64R5) || \
20e71b7053SJung-uk Kim       defined(_MIPS_ARCH_MIPS64R6)) \
21e71b7053SJung-uk Kim       && !defined(_MIPS_ARCH_MIPS64R2)
22e71b7053SJung-uk Kim #  define _MIPS_ARCH_MIPS64R2
23e71b7053SJung-uk Kim # endif
24e71b7053SJung-uk Kim 
25e71b7053SJung-uk Kim # if defined(_MIPS_ARCH_MIPS64R6)
26e71b7053SJung-uk Kim #  define dmultu(rs,rt)
27e71b7053SJung-uk Kim #  define mflo(rd,rs,rt)	dmulu	rd,rs,rt
28e71b7053SJung-uk Kim #  define mfhi(rd,rs,rt)	dmuhu	rd,rs,rt
29e71b7053SJung-uk Kim # elif defined(_MIPS_ARCH_MIPS32R6)
30e71b7053SJung-uk Kim #  define multu(rs,rt)
31e71b7053SJung-uk Kim #  define mflo(rd,rs,rt)	mulu	rd,rs,rt
32e71b7053SJung-uk Kim #  define mfhi(rd,rs,rt)	muhu	rd,rs,rt
33e71b7053SJung-uk Kim # else
34e71b7053SJung-uk Kim #  define dmultu(rs,rt)		dmultu	rs,rt
35e71b7053SJung-uk Kim #  define multu(rs,rt)		multu	rs,rt
36e71b7053SJung-uk Kim #  define mflo(rd,rs,rt)	mflo	rd
37e71b7053SJung-uk Kim #  define mfhi(rd,rs,rt)	mfhi	rd
38e71b7053SJung-uk Kim # endif
39e71b7053SJung-uk Kim 
40e71b7053SJung-uk Kim #endif
41