2016-09-01 16:39:15 +08:00
|
|
|
/*
|
|
|
|
* Copyright 2011-2016 The OpenSSL Project Authors. All Rights Reserved.
|
|
|
|
*
|
2018-12-06 21:03:01 +08:00
|
|
|
* Licensed under the Apache License 2.0 (the "License"). You may not use
|
2016-09-01 16:39:15 +08:00
|
|
|
* this file except in compliance with the License. You can obtain a copy
|
|
|
|
* in the file LICENSE in the source distribution or at
|
|
|
|
* https://www.openssl.org/source/license.html
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __MIPS_ARCH_H__
|
|
|
|
# define __MIPS_ARCH_H__
|
|
|
|
|
|
|
|
# if (defined(__mips_smartmips) || defined(_MIPS_ARCH_MIPS32R3) || \
|
|
|
|
defined(_MIPS_ARCH_MIPS32R5) || defined(_MIPS_ARCH_MIPS32R6))
|
|
|
|
&& !defined(_MIPS_ARCH_MIPS32R2)
|
|
|
|
# define _MIPS_ARCH_MIPS32R2
|
|
|
|
# endif
|
2016-10-11 00:01:24 +08:00
|
|
|
|
2016-09-01 16:39:15 +08:00
|
|
|
# if (defined(_MIPS_ARCH_MIPS64R3) || defined(_MIPS_ARCH_MIPS64R5) || \
|
|
|
|
defined(_MIPS_ARCH_MIPS64R6)) \
|
|
|
|
&& !defined(_MIPS_ARCH_MIPS64R2)
|
|
|
|
# define _MIPS_ARCH_MIPS64R2
|
|
|
|
# endif
|
|
|
|
|
|
|
|
# if defined(_MIPS_ARCH_MIPS64R6)
|
|
|
|
# define dmultu(rs,rt)
|
|
|
|
# define mflo(rd,rs,rt) dmulu rd,rs,rt
|
|
|
|
# define mfhi(rd,rs,rt) dmuhu rd,rs,rt
|
|
|
|
# elif defined(_MIPS_ARCH_MIPS32R6)
|
|
|
|
# define multu(rs,rt)
|
|
|
|
# define mflo(rd,rs,rt) mulu rd,rs,rt
|
|
|
|
# define mfhi(rd,rs,rt) muhu rd,rs,rt
|
|
|
|
# else
|
|
|
|
# define dmultu(rs,rt) dmultu rs,rt
|
|
|
|
# define multu(rs,rt) multu rs,rt
|
|
|
|
# define mflo(rd,rs,rt) mflo rd
|
|
|
|
# define mfhi(rd,rs,rt) mfhi rd
|
|
|
|
# endif
|
|
|
|
|
|
|
|
#endif
|