mirror of
https://github.com/rvtr/ctr_eFuse.git
synced 2025-11-02 00:11:04 -04:00
git-svn-id: file:///Volumes/Transfer/gigaleak_20231201/2020-09-30%20-%20paladin.7z/paladin/ctr_eFuse@6 ff987cc8-cf2f-4642-8568-d52cce064691
264 lines
15 KiB
C
264 lines
15 KiB
C
/* ====================================================================
|
||
* Copyright (c) 1998-2008 The OpenSSL Project. All rights reserved.
|
||
*
|
||
* Redistribution and use in source and binary forms, with or without
|
||
* modification, are permitted provided that the following conditions
|
||
* are met:
|
||
*
|
||
* 1. Redistributions of source code must retain the above copyright
|
||
* notice, this list of conditions and the following disclaimer.
|
||
*
|
||
* 2. Redistributions in binary form must reproduce the above copyright
|
||
* notice, this list of conditions and the following disclaimer in
|
||
* the documentation and/or other materials provided with the
|
||
* distribution.
|
||
*
|
||
* 3. All advertising materials mentioning features or use of this
|
||
* software must display the following acknowledgment:
|
||
* "This product includes software developed by the OpenSSL Project
|
||
* for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
|
||
*
|
||
* 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
|
||
* endorse or promote products derived from this software without
|
||
* prior written permission. For written permission, please contact
|
||
* openssl-core@openssl.org.
|
||
*
|
||
* 5. Products derived from this software may not be called "OpenSSL"
|
||
* nor may "OpenSSL" appear in their names without prior written
|
||
* permission of the OpenSSL Project.
|
||
*
|
||
* 6. Redistributions of any form whatsoever must retain the following
|
||
* acknowledgment:
|
||
* "This product includes software developed by the OpenSSL Project
|
||
* for use in the OpenSSL Toolkit (http://www.openssl.org/)"
|
||
*
|
||
* THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
|
||
* EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
|
||
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
||
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
||
* OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
* ====================================================================
|
||
*
|
||
* This product includes cryptographic software written by Eric Young
|
||
* (eay@cryptsoft.com). This product includes software written by Tim
|
||
* Hudson (tjh@cryptsoft.com).
|
||
*
|
||
*/
|
||
|
||
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
||
* All rights reserved.
|
||
*
|
||
* This package is an SSL implementation written
|
||
* by Eric Young (eay@cryptsoft.com).
|
||
* The implementation was written so as to conform with Netscapes SSL.
|
||
*
|
||
* This library is free for commercial and non-commercial use as long as
|
||
* the following conditions are aheared to. The following conditions
|
||
* apply to all code found in this distribution, be it the RC4, RSA,
|
||
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
||
* included with this distribution is covered by the same copyright terms
|
||
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
||
*
|
||
* Copyright remains Eric Young's, and as such any Copyright notices in
|
||
* the code are not to be removed.
|
||
* If this package is used in a product, Eric Young should be given attribution
|
||
* as the author of the parts of the library used.
|
||
* This can be in the form of a textual message at program startup or
|
||
* in documentation (online or textual) provided with the package.
|
||
*
|
||
* Redistribution and use in source and binary forms, with or without
|
||
* modification, are permitted provided that the following conditions
|
||
* are met:
|
||
* 1. Redistributions of source code must retain the copyright
|
||
* notice, this list of conditions and the following disclaimer.
|
||
* 2. Redistributions in binary form must reproduce the above copyright
|
||
* notice, this list of conditions and the following disclaimer in the
|
||
* documentation and/or other materials provided with the distribution.
|
||
* 3. All advertising materials mentioning features or use of this software
|
||
* must display the following acknowledgement:
|
||
* "This product includes cryptographic software written by
|
||
* Eric Young (eay@cryptsoft.com)"
|
||
* The word 'cryptographic' can be left out if the rouines from the library
|
||
* being used are not cryptographic related :-).
|
||
* 4. If you include any Windows specific code (or a derivative thereof) from
|
||
* the apps directory (application code) you must include an acknowledgement:
|
||
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
||
*
|
||
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||
* SUCH DAMAGE.
|
||
*
|
||
* The licence and distribution terms for any publically available version or
|
||
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
||
* copied and put under another distribution licence
|
||
* [including the GNU Public Licence.]
|
||
*/
|
||
|
||
#ifndef _CR_GENERATE_ID_H_
|
||
#define _CR_GENERATE_ID_H_
|
||
|
||
|
||
#define CR_GENID_SUCCESS 0
|
||
#define CR_GENID_ERROR_NON 0
|
||
#define CR_GENID_ERROR_RSA_ENC ( -1)
|
||
#define CR_GENID_ERROR_RSA_DEC ( -2)
|
||
#define CR_GENID_ERROR_RSA_VERIFY ( -3)
|
||
#define CR_GENID_ERROR_ECDSA_SIGN ( -4)
|
||
#define CR_GENID_ERROR_ECDSA_VERIFY ( -5)
|
||
#define CR_GENID_ERROR_SET_MEM_FUNCTIONS ( -6)
|
||
#define CR_GENID_ERROR_RSA_LOAD_PARAM ( -7)
|
||
#define CR_GENID_ERROR_EC_GENERATE_PRIVATE_KEY ( -8)
|
||
#define CR_GENID_ERROR_EC_GENERATE_PUBLIC_KEY ( -9)
|
||
#define CR_GENID_ERROR_RSA_READ_PRIVATE_KEY (-10)
|
||
#define CR_GENID_ERROR_RSA_READ_PUBLIC_KEY (-11)
|
||
#define CR_GENID_ERROR_BN_NEW_0 (-12)
|
||
#define CR_GENID_ERROR_BN_NEW_1 (-13)
|
||
#define CR_GENID_ERROR_BN_NEW_2 (-14)
|
||
#define CR_GENID_ERROR_BN_CTX_NEW (-15)
|
||
#define CR_GENID_ERROR_EC_POINT_NEW (-16)
|
||
#define CR_GENID_ERROR_EC_KEY_NEW_0 (-17)
|
||
#define CR_GENID_ERROR_EC_KEY_NEW_1 (-18)
|
||
#define CR_GENID_ERROR_ID_BUF_SIZE (-19)
|
||
#define CR_GENID_ERROR_ERR_BUF_SIZE (-20)
|
||
#define CR_GENID_ERROR_PRIVKEY_SCRAMBLE (-21)
|
||
|
||
// HSM<53><4D><EFBFBD><EFBFBD><EFBFBD>ɔ<EFBFBD><C994><EFBFBD><EFBFBD>lj<EFBFBD><C789>R<EFBFBD>[<5B>h
|
||
#define CR_GENID_ERROR_ACCESS_DENIED // Status_AccessDenied : <20><><EFBFBD><EFBFBD><EFBFBD>ƌ<EFBFBD><C68C><EFBFBD>ACL<43>̕s<CC95><73><EFBFBD>v<EFBFBD>ɔ<EFBFBD><C994><EFBFBD><EFBFBD>G<EFBFBD><47><EFBFBD>[
|
||
#define CR_GENID_ERROR_USE_LIMIT // Status_UseLimitExceeded : ACL<43>ɒ<EFBFBD><C992>߂<EFBFBD><DF82>ꂽ<EFBFBD>g<EFBFBD>p<EFBFBD><F1909482><F092B482><EFBFBD><EFBFBD>ꍇ
|
||
#define CR_GENID_ERROR_TIME_LIMIT // Status_TimeLimitExceeded : <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>s<EFBFBD><73><EFBFBD>܂ł̃^<5E>C<EFBFBD><43><EFBFBD><EFBFBD><EFBFBD>~<7E>b<EFBFBD>g(<28><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ACL)
|
||
#define CR_GENID_ERROR_SIGN_VERIFY // Status_VerifyFailed : <20><><EFBFBD><EFBFBD><EFBFBD>̌<EFBFBD><CC8C>Ɏ<D882><C98E>s<EFBFBD><73><EFBFBD><EFBFBD><EFBFBD>ꍇ -> OpenSSL<53>ōs<C58D><73><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>s<EFBFBD>v<EFBFBD>H
|
||
#define CR_GENID_ERROR_BAD_TOKEN // Status_BadTokenData : <20>J<EFBFBD>[<5B>h<EFBFBD>ANVRAM<41>A<EFBFBD>܂<EFBFBD><DC82><EFBFBD>RTC<54>̒l<CC92><6C><EFBFBD>s<EFBFBD><73>
|
||
#define CR_GENID_ERROR_NO_MEMORY // Status_NoMemory : (HSM<53><4D>)<29><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>g<EFBFBD><67><EFBFBD>ʂ<EFBFBD><CA82><EFBFBD><EFBFBD><EFBFBD> -> SEE<45>g<EFBFBD><67><EFBFBD>킯<EFBFBD>ł͂Ȃ<CD82><C882>̂ŕs<C595>v<EFBFBD><76><EFBFBD><EFBFBD>
|
||
#define CR_GENID_ERROR_NOT_SUPPORT // Status_UnknownParameter,Status_UnknownFlag,Status_UnknownMechanism : <20>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD>܂<EFBFBD><DC82>̓t<CD83><74><EFBFBD>O<EFBFBD>A<EFBFBD><41><EFBFBD>J<EFBFBD>j<EFBFBD>Y<EFBFBD><59>(<28>Í<EFBFBD><C38D>A<EFBFBD><41><EFBFBD>S<EFBFBD><53><EFBFBD>Y<EFBFBD><59><EFBFBD>Ȃ<EFBFBD>)<29><><EFBFBD>T<EFBFBD>|<7C>[<5B>g<EFBFBD><67><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882>AECC<43>n<EFBFBD>ŏo<C58F><6F><EFBFBD><EFBFBD><EFBFBD>H
|
||
#define CR_GENID_ERROR_KEY_TYPE // Status_BlobTypeUnknown : kmdata<74><61><EFBFBD>F<EFBFBD><46><EFBFBD>o<EFBFBD><6F><EFBFBD>Ȃ<EFBFBD> -> HDD<44>̕s<CC95><EFBFBD>Ŕ<EFBFBD><C594><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>H
|
||
#define CR_GENID_ERROR_BUFFER_FULL // Status_BufferFull : <20>Œ蒷<C592>o<EFBFBD>b<EFBFBD>t<EFBFBD>@<40><><EFBFBD>g<EFBFBD><67><EFBFBD>ʂ<EFBFBD><CA82><EFBFBD><EFBFBD><EFBFBD> -> <20><><EFBFBD><EFBFBD><EFBFBD>̃o<CC83>b<EFBFBD>t<EFBFBD>@<40>̘b<CC98><62><EFBFBD>H
|
||
#define CR_GENID_ERROR_HSM_RESET // Status_UnitReset : <20>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD><68><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>HSM<53><4D><EFBFBD>Z<EFBFBD>b<EFBFBD>g<EFBFBD><67><EFBFBD><EFBFBD> -> <20>ُ<EFBFBD><D98F>n
|
||
#define CR_GENID_ERROR_PARAM_INVALID // Status_InvalidParameter : <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>p<EFBFBD><70><EFBFBD><EFBFBD><EFBFBD>[<5B>^<5E>ݒ<EFBFBD>
|
||
#define CR_GENID_ERROR_STATUS_INVALID // Status_InvalidState : <20><><EFBFBD>W<EFBFBD><57><EFBFBD>[<5B><><EFBFBD>A<EFBFBD><41><EFBFBD>邢<EFBFBD><E982A2>API<50>̃<EFBFBD><CC83>x<EFBFBD><78>(e.g. Fips)<29><><EFBFBD><EFBFBD><EFBFBD>N<EFBFBD>G<EFBFBD>X<EFBFBD>g<EFBFBD><67><EFBFBD>ꂽ<EFBFBD>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD><68><EFBFBD><EFBFBD><EFBFBD>s<EFBFBD>ł<EFBFBD><C582><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ԂɂȂ<C982>
|
||
#define CR_GENID_ERROR_TOKEN_ASSEMBLE // Status_TokenAssemblyFailed : <20>g<EFBFBD>[<5B>N<EFBFBD><4E><EFBFBD>̍č\<5C>z<EFBFBD>Ɏ<EFBFBD><C98E>s<EFBFBD><73><EFBFBD><EFBFBD> -> <20>Z<EFBFBD>b<EFBFBD>g<EFBFBD>A<EFBFBD>b<EFBFBD>v<EFBFBD>̎<EFBFBD><CC8E>̂݁H
|
||
#define CR_GENID_ERROR_KEY_NOT_FOUND // Status_UnknownKM : HSM<53>L<EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD>t<EFBFBD><74><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD>
|
||
#define CR_GENID_ERROR_HSM_DEC // Status_DecryptFailed : <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ɏ<EFBFBD><C98E>s<EFBFBD><73><EFBFBD><EFBFBD>
|
||
#define CR_GENID_ERROR_PRAM_OUTOFRANGE // Status_OutOfRange : <20>p<EFBFBD><70><EFBFBD><EFBFBD><EFBFBD>[<5B>^<5E><><EFBFBD>͈͊O
|
||
#define CR_GENID_ERROR_PRIVILEGED_COMMAND // Status_PrivilegedCommand : <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڑ<EFBFBD><DA91>ɂ<EFBFBD><C982><EFBFBD><EFBFBD>ē<EFBFBD><C493><EFBFBD><EFBFBD>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD>s -> <20>{<7B>v<EFBFBD><76><EFBFBD>O<EFBFBD><4F><EFBFBD><EFBFBD><EFBFBD>ł͔<C582><CD94><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>悤<EFBFBD>ȃR<C883>}<7D><><EFBFBD>h<EFBFBD>͂Ȃ<CD82><C882>i<EFBFBD>͂<EFBFBD><CD82>j
|
||
#define CR_GENID_ERROR_KEY_HASH // Status_UnknownKeyHash : <20><><EFBFBD>̃n<CC83>b<EFBFBD>V<EFBFBD><56><EFBFBD>ƃ<EFBFBD><C683>W<EFBFBD><57><EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD>̃n<CC83>b<EFBFBD>V<EFBFBD><56><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>v<EFBFBD><76><EFBFBD>Ȃ<EFBFBD> -> <20><><EFBFBD><EFBFBD> or HDD<44>֘A<D698>ُ<EFBFBD>
|
||
#define CR_GENID_ERROR_HSM_ENC // Status_EncryptFailed : <20>Í<EFBFBD><C38D><EFBFBD><EFBFBD>Ɏ<EFBFBD><C98E>s<EFBFBD><73><EFBFBD><EFBFBD>
|
||
#define CR_GENID_ERROR_ACL_INVALID // Status_InvalidACL : ACL<43>ɖ<EFBFBD><C996><EFBFBD><EFBFBD><EFBFBD><EFBFBD>N<EFBFBD><4E><EFBFBD>Ă<EFBFBD><C482><EFBFBD> -> <20>Z<EFBFBD>b<EFBFBD>g<EFBFBD>A<EFBFBD>b<EFBFBD>v<EFBFBD><76><EFBFBD>̂<EFBFBD>
|
||
#define CR_GENID_ERROR_HSM_FAILED // Status_HardwareFailed : HSM<53>n<EFBFBD>[<5B>h<EFBFBD>G<EFBFBD><47><EFBFBD>[
|
||
#define CR_GENID_ERROR_SERVER_STOPPED // Status_ServerNotRunning : <20>T<EFBFBD>[<5B>o<EFBFBD><6F><EFBFBD><EFBFBD><EFBFBD>삵<EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD>
|
||
#define CR_GENID_ERROR_OS_ERROR // Status_OSErrorErrno : OS<4F><53>HSM<53>ƃv<C683><76><EFBFBD>O<EFBFBD><4F><EFBFBD><EFBFBD><EFBFBD>̒ʐM<CA90>𐋍s<F0908B8D>ł<EFBFBD><C582>Ȃ<EFBFBD>
|
||
#define CR_GENID_ERROR_TRANSACT_NOT_FOUND // Status_TransactionNotFound : NFastApp_Query or NFastApp_Wait <20>ő҂ׂ<C282><D782>g<EFBFBD><67><EFBFBD><EFBFBD><EFBFBD>U<EFBFBD>N<EFBFBD>V<EFBFBD><56><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> -> <20><><EFBFBD>͎g<CD8E><67><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882>̂ŕs<C595>v
|
||
#define CR_GENID_ERROR_CONNECTION_LOST // Status_ServerConnectionLost : HSM<53>ƒʐM<CA90><4D><EFBFBD>邽<EFBFBD>߂̃T<CC83>[<5B>o<EFBFBD>Ƃ̐ڑ<CC90><DA91><EFBFBD><EFBFBD>ꂽ<D882>B<EFBFBD>G<EFBFBD><47><EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ɣ<EFBFBD><C694><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƃ̂<C682><CC82><EFBFBD>
|
||
#define CR_GENID_ERROR_CONNECTION_FAILED // Status_ServerFailed : HSM<53>ƒʐM<CA90><4D><EFBFBD>邽<EFBFBD>߂̃T<CC83>[<5B>o<EFBFBD><6F> internal software <20>G<EFBFBD><47><EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>B<EFBFBD>N<EFBFBD><4E><EFBFBD>C<EFBFBD>A<EFBFBD><41><EFBFBD>g<EFBFBD><67><EFBFBD>̕s<CC95><73><EFBFBD>s<EFBFBD>ׂ<EFBFBD><D782><EFBFBD><EFBFBD><EFBFBD>
|
||
#define CR_GENID_ERROR_FIPS_MODE // Status_StrictFIPS140 : strict FIPS<50><53><EFBFBD>[<5B>h<EFBFBD>ŋ<EFBFBD><C58B><EFBFBD><C282><EFBFBD><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>s<EFBFBD><73><EFBFBD><EFBFBD> -> nShield500<30>ł<EFBFBD> strict FIPS<50><53><EFBFBD>[<5B>h<EFBFBD><68><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>͂<EFBFBD><CD82>Ȃ̂ŁA<C581>s<EFBFBD>v<EFBFBD>H
|
||
#define CR_GENID_ERROR_UNKNOWN_CODE // Status_UnknownStatus : <20>T<EFBFBD>[<5B>o<EFBFBD><6F>HSM<53>Ԃ̃o<CC83>[<5B>W<EFBFBD><57><EFBFBD><EFBFBD><EFBFBD>Ⴂ<EFBFBD>ŃX<C583>e<EFBFBD>[<5B>^<5E>X<EFBFBD>R<EFBFBD>[<5B>h<EFBFBD><68><EFBFBD><EFBFBD>ꗂ<EFBFBD><EA9782><EFBFBD><EFBFBD><EFBFBD> -> <20><><EFBFBD>Ԃ<D482><F194AD90><EFBFBD><EFBFBD>Ȃ<EFBFBD>
|
||
#define CR_GENID_ERROR_HSM_CANCELLED // Status_Cancelled : HSM<53>̏<EFBFBD><CC8F>Q<EFBFBD>E<EFBFBD><45><EFBFBD>Z<EFBFBD>b<EFBFBD>g<EFBFBD><67><EFBFBD>N<EFBFBD><4E><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD><C882>ߤ<EFBFBD>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD><68><EFBFBD>s<EFBFBD><73><EFBFBD>L<EFBFBD><4C><EFBFBD><EFBFBD><EFBFBD>Z<EFBFBD><5A><EFBFBD><EFBFBD><EFBFBD>ꂽ -> HSM<53>̌̏<CC8C><CC8F>H
|
||
#define CR_GENID_ERROR_CHANNEL_TYPE // Status_UnsupportedChannelType : <20>I<EFBFBD>[<5B>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD>悤<EFBFBD>Ƃ<EFBFBD><C682><EFBFBD><EFBFBD>`<60><><EFBFBD><EFBFBD><EFBFBD>l<EFBFBD><6C><EFBFBD>̃^<5E>C<EFBFBD>v<EFBFBD><76><EFBFBD>T<EFBFBD>|<7C>[<5B>g<EFBFBD><67><EFBFBD>ĂȂ<C482> -> <20><><EFBFBD>̓`<60><><EFBFBD><EFBFBD><EFBFBD>l<EFBFBD><6C><EFBFBD><EFBFBD><EFBFBD>g<EFBFBD><67><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD>A<EFBFBD><41><EFBFBD><EFBFBD><EFBFBD>g<EFBFBD><67><EFBFBD>\<5C>w<EFBFBD><77><EFBFBD><EFBFBD>
|
||
#define CR_GENID_ERROR_BIGNUMOP_ARITHMETIC // Status_ArithmeticError : Bignum<75><6D><EFBFBD><EFBFBD><EFBFBD>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD><68> 0 <20>Ŋ<EFBFBD><C58A><EFBFBD><EFBFBD>悤<EFBFBD>ȕs<C895><73><EFBFBD>Ȍv<C88C>Z<EFBFBD><5A><EFBFBD>s<EFBFBD><73><EFBFBD><EFBFBD><EFBFBD>Ƃ<EFBFBD><C682><EFBFBD>
|
||
#define CR_GENID_ERROR_BIGNUMOP_STACK_OVERFLOW // Status_OpStackOverflow : Bignum<75><6D><EFBFBD><EFBFBD><EFBFBD>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD><68><EFBFBD><EFBFBD><EFBFBD>X<EFBFBD>^<5E>b<EFBFBD>N<EFBFBD>̃G<CC83><47><EFBFBD>g<EFBFBD><67><EFBFBD><EFBFBD><EFBFBD><EFBFBD><F092B482><EFBFBD>Push<73><68><EFBFBD>s<EFBFBD><73><EFBFBD><EFBFBD><EFBFBD>Ƃ<EFBFBD><C682><EFBFBD>
|
||
#define CR_GENID_ERROR_BIGNUMOP_STACK_UNDERFLOW // Status_OpStackUnderflow : Bignum<75><6D><EFBFBD><EFBFBD><EFBFBD>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD><68><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>X<EFBFBD>^<5E>b<EFBFBD>N<EFBFBD><4E><EFBFBD><EFBFBD>Pop<6F><70><EFBFBD>s<EFBFBD><73><EFBFBD><EFBFBD><EFBFBD>Ƃ<EFBFBD><C682><EFBFBD>
|
||
#define CR_GENID_ERROR_BIGNUMOP_NEGATIVE // Status_NegativeResult : Bignum<75><6D><EFBFBD><EFBFBD><EFBFBD>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD>̌<EFBFBD><CC8C>ʂɕ<CA82><C995>̒l<CC92><6C><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>(<28><><EFBFBD>AAllowNegtive<76>t<EFBFBD><74><EFBFBD>O<EFBFBD><4F><EFBFBD>Z<EFBFBD>b<EFBFBD>g<EFBFBD><67><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD><EFBFBD>)
|
||
#define CR_GENID_ERROR_BIGNUMOP_NOUPCALL // Status_NoUpCall : Bignum<75><6D><EFBFBD>삪<EFBFBD>K<EFBFBD>v<EFBFBD>ȃR<C883>}<7D><><EFBFBD>h<EFBFBD><68><EFBFBD>Ăꂽ<CE82>Ƃ<EFBFBD><C682>ABignum<75><6D><EFBFBD><EFBFBD><EFBFBD><EFBFBD><D690><EFBFBD><EFBFBD>o<EFBFBD>^<5E><><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD><EFBFBD> -> NFastApp_SetBignumUpcalls() <20><><EFBFBD>K<EFBFBD>v
|
||
#define CR_GENID_ERROR_SOFTWARE_FAILED // Status_SoftwareFailed : <20>z<EFBFBD>X<EFBFBD>g<EFBFBD>\<5C>t<EFBFBD>g<EFBFBD>E<EFBFBD>F<EFBFBD>A<EFBFBD>ŋN<C58B><4E><EFBFBD><EFBFBD><EFBFBD>G<EFBFBD><47><EFBFBD>[ -> netHSM<53>֘A<D698>H
|
||
#define CR_GENID_ERROR_NO_HOST_MEMORY // Status_NoHostMemory : <20>z<EFBFBD>X<EFBFBD>g<EFBFBD><67><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>g<EFBFBD><67><EFBFBD>ʂ<EFBFBD><CA82><EFBFBD><EFBFBD><EFBFBD> -> netHSM<53>֘A<D698>H
|
||
#define CR_GENID_ERROR_NO_MODULE_MEMORY // Status_NoModuleMemory : HSM<53><4D><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>g<EFBFBD><67><EFBFBD>ʂ<EFBFBD><CA82><EFBFBD><EFBFBD><EFBFBD> -> netHSM<53>֘A<D698>H
|
||
#define CR_GENID_ERROR_OPERATION_FAILED // Status_OperationFailed : nCipher<65>T<EFBFBD>[<5B>o<EFBFBD>ŕs<C595><73><EFBFBD>ȑ<EFBFBD><C891>삪<EFBFBD><EC82AA><EFBFBD>s<EFBFBD><73><EFBFBD>ꂽ -> netHSM<53>֘A<D698>H
|
||
#define CR_GENID_ERROR_NC_ERR // Status_nCErrno : OS<4F>G<EFBFBD><47><EFBFBD>[ -> netHSM<53><4D>OS<4F>̃G<CC83><47><EFBFBD>[<5B><><EFBFBD>H
|
||
#define CR_GENID_ERROR_NO_PERMID // Status_UnknownPermID : <20><><EFBFBD>蓖<EFBFBD>Ă<EFBFBD><C482><EFBFBD><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD>PermID
|
||
#define CR_GENID_ERROR_OP_TIMEOUT // Status_OperationTimeout : <20><><EFBFBD>W<EFBFBD><57><EFBFBD>[<5B><><EFBFBD>ɐݒ肳<DD92><E882B3><EFBFBD>Ă<EFBFBD><C482><EFBFBD>timelimit<69>ȓ<EFBFBD><C893>ɃR<C983>}<7D><><EFBFBD>h<EFBFBD><68><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD><EFBFBD> -> key <20><> time limit <20>Ƃ͂܂<CD82><DC82>ʁH
|
||
#define CR_GENID_ERROR_UNKNOWN_KEY // Status_UnknownKey : <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>W<EFBFBD><57><EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD>Ō<EFBFBD><C58C>t<EFBFBD><74><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD><EFBFBD>
|
||
#define CR_GENID_ERROR_KEY_LOAD // Status_KeyNotLoaded : <20><><EFBFBD>N<EFBFBD>G<EFBFBD>X<EFBFBD>g<EFBFBD><67><EFBFBD>ꂽ<EFBFBD><EA82BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>t<EFBFBD><74><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD><EFBFBD>(NFKM<4B><4D><EFBFBD>C<EFBFBD>u<EFBFBD><75><EFBFBD><EFBFBD>)
|
||
#define CR_GENID_ERROR_HSM_NOUSABLE // Status_NoUsableModules : <20><><EFBFBD>p<EFBFBD>\<5C>ȃ<EFBFBD><C883>W<EFBFBD><57><EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>݂<EFBFBD><DD82>Ȃ<EFBFBD>(NFKM<4B><4D><EFBFBD>C<EFBFBD>u<EFBFBD><75><EFBFBD><EFBFBD>)
|
||
#define CR_GENID_ERROR_WORLD_UNUSABLE // Status_WorldUnsable : <20><><EFBFBD>݂̃Z<CC83>L<EFBFBD><4C><EFBFBD><EFBFBD><EFBFBD>e<EFBFBD>B<EFBFBD><42><EFBFBD>[<5B><><EFBFBD>h<EFBFBD><68><EFBFBD>g<EFBFBD>p<EFBFBD>s<EFBFBD>ł<C282><C582><EFBFBD><EFBFBD>B
|
||
#define CR_GENID_ERROR_MANY_LINKS // Status_TooManyLinks : Blob<6F><62><EFBFBD>ǂݍ<C782><DD8D><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƃ<EFBFBD><C682><EFBFBD><EFBFBD>Ƃ<EFBFBD><C682>A<EFBFBD><41><EFBFBD>W<EFBFBD><57><EFBFBD>[<5B><><EFBFBD>̋<EFBFBD><CC8B><EFBFBD><C282><EFBFBD><EFBFBD>ȏ<EFBFBD>(5)<29>̑<EFBFBD><CC91><EFBFBD><EFBFBD>̃G<CC83>C<EFBFBD><43><EFBFBD>A<EFBFBD>X<EFBFBD><58><EFBFBD><EFBFBD><EFBFBD>݂<EFBFBD><DD82><EFBFBD>
|
||
#define CR_GENID_ERROR_USELIMIT_UNAVAILABLE // Status_UseLimitsUnavailable : <20><><EFBFBD><EFBFBD><EFBFBD>K<EFBFBD><EFBFBD>USE LIMIT<49><54><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD>
|
||
#define CR_GENID_ERROR_HSM_BUSY // Status_Busy : <20><><EFBFBD>W<EFBFBD><57><EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ł<EFBFBD><C582><EFBFBD><EFBFBD>B -> <20><><EFBFBD><EFBFBD><EFBFBD>͔<EFBFBD><CD94><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD><C882>H<EFBFBD>i<EFBFBD>͂<EFBFBD><CD82>j
|
||
#define CR_GENID_ERROR_MODULE_UNUSABLE // Status_ModuleNotUsable : <20><><EFBFBD>W<EFBFBD><57><EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>p<EFBFBD>s<EFBFBD>ł<C282><C582><EFBFBD><EFBFBD>B(NFKM<4B><4D><EFBFBD>C<EFBFBD>u<EFBFBD><75><EFBFBD><EFBFBD>)
|
||
#define CR_GENID_ERROR_REPLY_MISMATCH // Status_CommandReplyMismatch = 238, : reply <20><> command <20>ƈ<EFBFBD><C688>v<EFBFBD><76><EFBFBD>Ȃ<EFBFBD><C882>B
|
||
#define CR_GENID_ERROR_CONFLICT_PARAM // Status_ConflictingParameters = 239, : <20>p<EFBFBD><70><EFBFBD><EFBFBD><EFBFBD>[<5B>^<5E><><EFBFBD>Փ˂<D593><CB82>Ă<EFBFBD><C482><EFBFBD><EFBFBD>B(<28>f<EFBFBD>[<5B>^<5E>x<EFBFBD>[<5B>X<EFBFBD>H)
|
||
#define CR_GENID_ERROR_DATA_MISMATCH // Status_DataMismatch = 240, : <20>f<EFBFBD>[<5B>^<5E>x<EFBFBD>[<5B>X<EFBFBD>H<EFBFBD>̃f<CC83>[<5B>^<5E><><EFBFBD>\<5C><><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482><EFBFBD><EFBFBD>f<EFBFBD>[<5B>^<5E>ƃ}<7D>b<EFBFBD>`<60><><EFBFBD>Ȃ<EFBFBD><C882>B
|
||
#define CR_GENID_ERROR_KEY_NOACTIVE // Status_NoActiveKey = 242, : <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>烍<EFBFBD>[<5B>h<EFBFBD><68><EFBFBD>悤<EFBFBD>Ƃ<EFBFBD><C682><EFBFBD><EFBFBD><EFBFBD><EFBFBD>A<EFBFBD><41><EFBFBD>̌<EFBFBD><CC8C><EFBFBD><EFBFBD>͌<EFBFBD><CD8C>݃n<DD83><6E><EFBFBD>h<EFBFBD><68><EFBFBD><EFBFBD><EFBFBD>O<EFBFBD><4F><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD>̂ł<CC82><C582><EFBFBD><EFBFBD>B
|
||
#define CR_GENID_ERROR_NOGROUP_PERM // Status_NoGroupPermission = 244, : <20>G<EFBFBD><47><EFBFBD>h<EFBFBD>|<7C>C<EFBFBD><43><EFBFBD>g<EFBFBD>H<EFBFBD><48><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>t<EFBFBD>F<EFBFBD>b<EFBFBD>`<60><><EFBFBD>悤<EFBFBD>Ƃ<EFBFBD><C682><EFBFBD><EFBFBD><EFBFBD><EFBFBD>A<EFBFBD>K<EFBFBD>ȃO<C883><4F><EFBFBD>[<5B>v<EFBFBD>p<EFBFBD>[<5B>~<7E>b<EFBFBD>V<EFBFBD><56><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>t<EFBFBD><74><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD><EFBFBD>
|
||
#define CR_GENID_ERROR_STRICT_FIPS // Status_StrictFIPSSecurityLevel = 275, : strict FIPS<50><53><EFBFBD>[<5B>h<EFBFBD>ŋ<EFBFBD><C58B><EFBFBD><C282><EFBFBD><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>s<EFBFBD><73><EFBFBD><EFBFBD>
|
||
#define CR_GENID_ERROR_TIME_OUTOFRANGE // Status_TimeOutOfRange = 283, : Time <20><> time_t<5F>̒l<CC92>͈̔͂<CD82><F092B482><EFBFBD> -> <20><><EFBFBD><EFBFBD> Time<6D>H
|
||
#define CR_GENID_ERROR_STATUS_MAX // Status__Max = 288 : HSM <20>̃G<CC83><47><EFBFBD>[<5B>R<EFBFBD>[<5B>h<EFBFBD>̍ő<CC8D><C591>l
|
||
|
||
|
||
// <20>ڍוs<D795><73>
|
||
// Status_HostDataInvalid = 70,
|
||
// Status_HostDataAccessFailed = 71,
|
||
// Status_HostDataAccessDenied = 86,
|
||
// Status_InvalidMergedKey = 87,
|
||
// Status_AlreadyExists = 88,
|
||
// Status_UserCancelled = 131,
|
||
// Status_HostUnknownKeyType = 133,
|
||
// Status_IncorrectRepositoryName = 134,
|
||
// Status_SecurityWorldFeatureDisabled = 143,
|
||
// Status_UnknownESN = 213,
|
||
|
||
|
||
|
||
#ifdef __cplusplus
|
||
extern "C" {
|
||
#endif
|
||
|
||
typedef signed char s8;
|
||
typedef unsigned char u8;
|
||
typedef unsigned short u16;
|
||
typedef signed long s32;
|
||
typedef unsigned long u32;
|
||
typedef unsigned long long u64;
|
||
|
||
//#define DEBUG_PRINT 1
|
||
|
||
#ifdef USE_SFMT
|
||
#include "SFMT.h"
|
||
#endif /* USE_SFMT */
|
||
|
||
#define CR_ID_BUF_SIZE (2048/8)
|
||
#define CR_NUM_OF_SERIAL 5
|
||
|
||
/*
|
||
serial <20><> <20><><EFBFBD>ۂ<EFBFBD>ID <20>Ƃ̊W<D68C>́A<CD81><41><EFBFBD>L<EFBFBD>̂悤<CC82>ɂȂ<C982><C882>Ă<EFBFBD><C482>܂<EFBFBD><DC82>B
|
||
ID0 = serial[ 0 ]
|
||
ID1 = serial[ 1 ] | ( serial[ 2 ] << 32 )
|
||
ID2 = serial[ 3 ] | ( serial[ 4 ] << 32 )
|
||
*/
|
||
|
||
// Nintendo ID <20>d<EFBFBD>l
|
||
#define CR_ID0_BIT_NUM 32
|
||
#define CR_ID1_BIT_NUM 34
|
||
#define CR_ID2_BIT_NUM 64
|
||
#define CR_ID0_MASK 0xFFFFFFFF // 32bit
|
||
#define CR_ID1_MASK 0x00000003FFFFFFFFll // 34bit
|
||
#define CR_ID2_MASK 0xFFFFFFFFFFFFFFFFll // 64bit
|
||
|
||
int cr_generate_id_initialize( void );
|
||
int cr_generate_id_finalize( void );
|
||
|
||
int cr_generate_id( u32 serial[CR_NUM_OF_SERIAL], u8 id[CR_ID_BUF_SIZE], u8 bondingOption );
|
||
|
||
extern int cr_print_flag;
|
||
|
||
#ifdef __cplusplus
|
||
}
|
||
#endif
|
||
|
||
|
||
#endif /* _CR_GENERATE_ID_H_ */
|
||
|