Fixes a few memory leaks in debug code Fix for big-endian support Sync test vectors for prof testing
103 lines
25 KiB
C
103 lines
25 KiB
C
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <ctype.h>
|
|
#include <rng.h>
|
|
#include <sig.h>
|
|
#include <api.h>
|
|
|
|
// Some hardcoded vectors for profiling
|
|
|
|
#if CRYPTO_PUBLICKEYBYTES == 64
|
|
const unsigned char pk[] = {0x9C,0xD1,0x15,0x09,0x55,0x1D,0x64,0x17,0x07,0xA4,0xD8,0x96,0x58,0x60,0xCD,0x0F,0xD7,0x82,0xCC,0x1C,0x87,0x25,0xB5,0x42,0xC4,0xDC,0x78,0x5D,0xEE,0xCA,0x56,0x24,0x2E,0xC6,0x7D,0x92,0x45,0xCD,0x46,0x4B,0x83,0x85,0x54,0xD3,0xA7,0xFA,0x4F,0x1D,0x90,0xC1,0x47,0x36,0xF8,0x24,0x4E,0x21,0x1D,0x6E,0x31,0xBD,0xB9,0x8D,0x50,0x0C};
|
|
const unsigned char sk[] = {0x9C,0xD1,0x15,0x09,0x55,0x1D,0x64,0x17,0x07,0xA4,0xD8,0x96,0x58,0x60,0xCD,0x0F,0xD7,0x82,0xCC,0x1C,0x87,0x25,0xB5,0x42,0xC4,0xDC,0x78,0x5D,0xEE,0xCA,0x56,0x24,0x2E,0xC6,0x7D,0x92,0x45,0xCD,0x46,0x4B,0x83,0x85,0x54,0xD3,0xA7,0xFA,0x4F,0x1D,0x90,0xC1,0x47,0x36,0xF8,0x24,0x4E,0x21,0x1D,0x6E,0x31,0xBD,0xB9,0x8D,0x50,0x0C,0x02,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xAF,0x71,0x87,0xCD,0xA3,0x13,0xF3,0x7F,0xF9,0xF3,0xFD,0xAB,0xC6,0x25,0x48,0xF9,0x69,0xF2,0x5C,0xAB,0x3B,0xF9,0xAD,0x2C,0x79,0x07,0x22,0x7C,0xA6,0xAD,0x10,0xF3,0x64,0x9A,0xD7,0xF3,0x68,0xB6,0xCD,0x97,0xD7,0x6F,0xF5,0x67,0x29,0xE9,0x03,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xFA,0xB3,0x43,0xC8,0x0E,0xF4,0x16,0xB8,0xBE,0x87,0x4E,0x2F,0x6D,0x2D,0xA7,0x38,0x00,0x81,0x24,0x17,0x38,0x44,0xDB,0x60,0x19,0xB7,0xB8,0x23,0xC4,0x9E,0xB7,0xD1,0x1B,0x46,0x6C,0x99,0xDC,0xCD,0xF9,0xBD,0x34,0x1F,0x73,0x0E,0x92,0x32,0xFE,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xEE,0x8D,0x38,0xC1,0x1F,0xF3,0xB5,0x0E,0x8B,0xED,0x00,0x09,0x48,0xC0,0x60,0x4D,0x63,0xCB,0xC8,0x94,0x3C,0xAD,0x5A,0x0F,0xCD,0x1A,0xBF,0x81,0x30,0x81,0xFB,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xBF,0xC9,0x2E,0x58,0x2C,0xC3,0x50,0x79,0xFA,0x93,0x64,0x3B,0x1F,0x12,0xB3,0xF0,0x86,0x43,0xF6,0xBB,0xAA,0x1B,0xB4,0x3E,0xBB,0x60,0x1D,0x25,0x4D,0x03,0x0C,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x8E,0xF4,0xD1,0x0A,0x6D,0x33,0x6B,0x5F,0x52,0xCD,0x54,0x9A,0x2E,0x38,0x48,0xD1,0xDA,0xE6,0xDF,0x6D,0x25,0x78,0x1D,0x0F,0x22,0x06,0x23,0x25,0xD7,0xB5,0xCA,0x17,0x00,0xF2,0xDC,0xC3,0x7B,0x1C,0x21,0x2B,0x00,0x3D,0xD8,0x58,0x66,0x36,0xBE,0x3A,0x87,0x89,0xA4,0x05,0x11,0x67,0x93,0xCA,0xBE,0x12,0xD7,0xE5,0xB2,0x6B,0xCC,0x21,0x7C,0x1D,0x15,0x74,0x80,0x36,0xC1,0x80,0x65,0xAD,0x55,0x16,0x20,0xEF,0xA2,0x34,0xF6,0x54,0x76,0xEE,0x48,0xC3,0xA5,0x04,0x81,0x18,0x96,0x63,0x36,0x3D,0x44,0x11,0xE7,0xED,0xD0,0xB9,0xBA,0xC2,0xC9,0x3B,0xD5,0xB3,0x49,0x40,0x96,0xB7,0xD0,0xEF,0xF8,0xF1,0xF3,0xE3,0x48,0x1F,0x38,0x69,0xBB,0xBB,0x51,0xE2,0x4B,0x16,0x1C,0x24,0x20,0x12,0xF7,0x9E,0x4A,0x62,0x50,0xFE,0x4C,0xD6,0x69,0x9D,0x7E,0x38,0x24,0xD3,0x5E,0x48,0x47,0xE7,0x43,0xA0,0x7B,0x09,0x14,0x04,0xA6,0xBD,0x71,0xD7,0x5D,0x2D,0x7D,0x09,0x62,0xC9,0xF5,0x1B,0x1C,0xFE,0x30,0x0A,0xA1,0xFA,0xD4,0xC0,0x13,0x1E,0x69,0x06,0x6D,0x83,0x2E,0x3D,0x5E,0x46,0x20,0x30,0xDD,0x90,0xE7,0xD2,0x5A,0x28,0x19,0x07,0x47,0x5E,0x62,0xA3,0xDE,0x15,0x71,0xCA,0x21,0x57,0xC7,0x1E,0xE3,0x7F,0xC1,0x94,0x5A,0x84,0x04,0x08,0xE6,0xC6,0xDB,0x4C,0x4D,0x50,0x6A,0x27,0xEB,0x24,0xEF,0x8E,0x23,0x96,0x66,0xA6,0x63,0xF6,0x33,0xA6,0xF7,0x66,0xDF,0xE1,0x27,0xB3,0x27,0x80,0xAF,0xC0,0x6E,0x2E,0x5A,0x86,0xD8,0x6F,0xB9,0xA2,0x53,0xDD,0xD5,0x31,0xA3,0x8E,0x64,0x16,0xE4,0xFD,0x5F,0x12,0x39,0x99,0x57,0xCC,0x87,0x29,0x24,0x6C,0xB1,0xD5,0xD5,0x72,0x19,0xA5,0xAA,0x35,0xBE,0x69,0xA8,0x21,0x33,0x8D,0x0D,0x14,0xE5,0xAA,0x83,0xE6,0x3F,0x84,0x3C,0x0E,0x5C,0x4F,0xAB,0x40,0xFB,0xAB,0x31,0x5D,0x01,0x9A,0xDC,0x0D,0x29,0xA2,0x7B,0xB5,0xD9,0x8E,0x39,0x77,0xC5,0x16,0x31,0x0A,0xE2,0x1D,0x41,0xBD,0x0D,0xAC,0xCC,0x99,0x40,0xA4,0xCF,0x2A,0x36,0x33,0xE5,0x3A,0xF5,0x34,0xA7,0xA4,0x6E,0xA3,0x9A,0x2D,0x75,0xAB,0xBB,0x41,0x70,0xA3,0x99,0x0F,0xCD,0xA5,0xF7,0x97,0x91,0x85,0x25,0x2A,0xAB,0x38,0xA9,0x27,0x08,0x6D,0xFD,0x3C,0x0C,0x96,0x04,0x0F,0xA6,0xA8,0xC8,0x77,0x69,0xD6,0xDF,0xD4,0xBC,0x47,0xBE,0x0D,0x38,0x37,0x2C,0xE5,0x9B,0xCD,0x4C,0xDD,0xE3,0x24,0xDA,0x73,0x17,0x65,0xEB,0x43,0x0F,0x85,0x84,0xD7,0x4D,0x83,0x98,0xC7,0x3C,0xB8,0x75,0x4E,0x91,0x8C,0x37,0x07,0x61,0x28,0xC2,0xC8,0x92,0x62,0xA1,0xA2,0xBE,0x43,0x62,0xCF,0xF1,0x95,0xD4,0xA2,0x76,0xBE,0x74,0x7E,0x57,0x27,0xFF,0x58,0xA7,0xFE,0xB0,0xB4,0xCF,0x24,0x7F,0x1B};
|
|
const unsigned char sm[] = {0xB2,0x9C,0xA1,0x76,0x40,0xDD,0x8D,0x78,0xA0,0x01,0xD6,0xF9,0x9D,0x80,0x69,0x9D,0x24,0xDB,0xB1,0x04,0xDF,0xD7,0x05,0x6D,0xA5,0x6F,0x2D,0xBF,0xD7,0x04,0xF7,0x56,0x18,0xFC,0x79,0x6B,0xEA,0x04,0x0E,0x06,0x12,0x45,0x0C,0xB5,0x88,0x55,0x3B,0x93,0x65,0x02,0x1A,0x3E,0x7B,0xC1,0xD5,0xCB,0x83,0xC8,0x25,0x05,0x6C,0xC7,0xE8,0xB2,0x03,0x85,0xB1,0x69,0xBA,0x04,0x79,0xA1,0x58,0xDB,0x7F,0x6F,0xE2,0x29,0x28,0x00,0xAE,0xBE,0xED,0x83,0xCC,0x6F,0x77,0x5C,0x9D,0x02,0xFE,0x2F,0x3C,0xFC,0xFE,0x3A,0x78,0x9E,0x89,0x05,0x1B,0xBE,0x86,0xD0,0xE2,0x94,0xA2,0xE3,0xAE,0x04,0xF0,0xAE,0x5A,0xE4,0x81,0x8C,0x5F,0xEA,0x17,0x02,0x6F,0xC9,0x04,0xC8,0x70,0x7B,0x07,0x8C,0xD5,0x06,0x2C,0xBF,0xB0,0x01,0x9E,0x51,0x39,0xB8,0xE3,0x07,0x00,0x73,0x64,0x1A,0xF4,0x20,0x36,0x39,0xA9,0xE6,0x35,0xDD,0x31,0x2C,0x16,0x9C,0x5B,0x0A,0x00,0xC6,0x22,0x3B,0xC7,0x4D,0xE2,0x8D,0x76,0xF1,0x04,0x06,0x4E,0x28,0x00,0xA8,0xAC,0xF7,0x00,0xD8,0x1C,0x4D,0x8D,0x73,0x4F,0xCB,0xFB,0xEA,0xDE,0x3D,0x3F,0x8A,0x03,0x9F,0xAA,0x2A,0x2C,0x99,0x57,0xE8,0x35,0xAD,0x55,0xB2,0x2E,0x75,0xBF,0x57,0xBB,0x55,0x6A,0xC8};
|
|
const unsigned char msg[] = {0xD8,0x1C,0x4D,0x8D,0x73,0x4F,0xCB,0xFB,0xEA,0xDE,0x3D,0x3F,0x8A,0x03,0x9F,0xAA,0x2A,0x2C,0x99,0x57,0xE8,0x35,0xAD,0x55,0xB2,0x2E,0x75,0xBF,0x57,0xBB,0x55,0x6A,0xC8};
|
|
const unsigned long long mlen = 33;
|
|
#elif CRYPTO_PUBLICKEYBYTES == 96
|
|
const unsigned char pk[] = {0xC5,0xCD,0x57,0x1D,0xF8,0x66,0x30,0xA9,0x3C,0x72,0xB4,0x15,0x95,0xD1,0xFC,0x20,0xD2,0x58,0x09,0x55,0x88,0xCB,0x64,0x09,0xFE,0xA9,0xA4,0xE1,0x83,0xB8,0x66,0xC7,0x7D,0x2F,0x42,0x3A,0x75,0x59,0xFB,0x3D,0x6E,0x1A,0xDF,0x06,0x04,0xB3,0x68,0x02,0xDD,0xC5,0xC9,0x42,0x0E,0x8E,0xC5,0x5D,0x54,0x7F,0xB0,0x2B,0x83,0x34,0x6D,0xC9,0xCC,0x18,0x57,0xEB,0x58,0x9E,0xE9,0x4E,0x66,0x6B,0x37,0xD8,0xC5,0xF2,0xDF,0x6B,0xBB,0xD3,0xEA,0xE8,0xE2,0x80,0x78,0xD5,0x46,0x59,0x76,0x5E,0x2F,0xCF,0xCD,0x00};
|
|
const unsigned char sk[] = {0xC5,0xCD,0x57,0x1D,0xF8,0x66,0x30,0xA9,0x3C,0x72,0xB4,0x15,0x95,0xD1,0xFC,0x20,0xD2,0x58,0x09,0x55,0x88,0xCB,0x64,0x09,0xFE,0xA9,0xA4,0xE1,0x83,0xB8,0x66,0xC7,0x7D,0x2F,0x42,0x3A,0x75,0x59,0xFB,0x3D,0x6E,0x1A,0xDF,0x06,0x04,0xB3,0x68,0x02,0xDD,0xC5,0xC9,0x42,0x0E,0x8E,0xC5,0x5D,0x54,0x7F,0xB0,0x2B,0x83,0x34,0x6D,0xC9,0xCC,0x18,0x57,0xEB,0x58,0x9E,0xE9,0x4E,0x66,0x6B,0x37,0xD8,0xC5,0xF2,0xDF,0x6B,0xBB,0xD3,0xEA,0xE8,0xE2,0x80,0x78,0xD5,0x46,0x59,0x76,0x5E,0x2F,0xCF,0xCD,0x00,0x02,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xA6,0x25,0xA3,0xE9,0x72,0x58,0x8F,0xA8,0x1D,0xF7,0x63,0x37,0x83,0xA0,0x7C,0x17,0x06,0x82,0x14,0x32,0xC9,0x75,0xD2,0x7F,0x15,0xA3,0x4F,0xA6,0x7B,0x9D,0x22,0x5A,0xDA,0xCE,0xD4,0xDE,0x4B,0x43,0xD8,0xFC,0x47,0xCE,0x7D,0x27,0xED,0x46,0x91,0x5D,0x23,0xB7,0xC4,0x24,0x09,0x7C,0x49,0xDA,0xF3,0x08,0x3D,0x63,0x80,0x19,0xA4,0x08,0xE2,0x60,0x0D,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x65,0x08,0x56,0xD9,0x6E,0xDE,0x15,0xB6,0x89,0xCE,0x0A,0xAC,0x09,0xEB,0xD7,0x57,0x79,0xA4,0xC3,0xE7,0x81,0x6D,0x66,0x39,0x2E,0xF0,0x0A,0xCA,0x5A,0x17,0x4C,0x39,0x1A,0xBB,0x6D,0xF1,0x70,0x6D,0x1A,0xCE,0x4E,0xC4,0x56,0xC7,0x17,0x03,0xE7,0x33,0x45,0x8A,0x34,0xE4,0xA6,0x5E,0xE8,0xBD,0x4A,0x59,0x0E,0x8F,0xB7,0x6B,0xDC,0x3F,0xA5,0x1A,0x02,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x45,0x1F,0x15,0xE0,0x2A,0xF5,0xA3,0x79,0x65,0x77,0xD5,0x10,0x00,0xD0,0xAE,0xDA,0xAD,0x34,0x4F,0xB7,0xBD,0x70,0xCE,0x10,0x69,0x0A,0x93,0xBF,0xE3,0xEB,0xFE,0x10,0x66,0xB1,0x7B,0x6B,0x9F,0x8B,0x19,0x76,0xEC,0x07,0x4A,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xD6,0x0B,0x88,0x66,0xD7,0xE3,0x4F,0x7D,0xC0,0x7F,0xD5,0xB3,0x84,0xEA,0x6C,0xDA,0xD7,0xE5,0xC3,0x3C,0xAC,0x15,0xB2,0x03,0x5B,0xB1,0x1F,0x6B,0x63,0x7C,0x4B,0x61,0xC0,0xC1,0x9B,0xF3,0xC2,0xBB,0xD7,0x2A,0x14,0x1F,0xDC,0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x50,0x94,0x18,0xE5,0xDA,0xBD,0x77,0x87,0xAF,0x06,0xC1,0x41,0x85,0x3A,0x09,0x7D,0xBC,0x38,0x49,0x98,0xA7,0x71,0x36,0xB9,0x94,0x4C,0x83,0x98,0xB0,0x9C,0x49,0x58,0x70,0x37,0xD8,0x99,0x9B,0x47,0xA5,0x76,0x22,0xEA,0xF2,0x3A,0xDF,0x63,0x4F,0x01,0x14,0x2E,0xA3,0x26,0x36,0x17,0x90,0x4D,0xD6,0x1C,0xA2,0x9F,0x8C,0x0A,0xE5,0x47,0x14,0x3E,0x5A,0x59,0xF4,0x35,0x7E,0xBE,0x87,0xE5,0xC6,0x7A,0x3F,0xE2,0x8F,0x49,0xAC,0x8B,0xC6,0x1C,0xE6,0x93,0x8A,0x29,0x76,0x08,0x85,0x58,0xAD,0x7E,0xFA,0x02,0x5B,0xFC,0x8F,0xB9,0x40,0x46,0x58,0x00,0xFB,0x71,0xD1,0x34,0x70,0x90,0xAD,0x23,0xEE,0xC7,0xF1,0x9B,0x60,0x99,0xC5,0xCF,0xC3,0x07,0xF2,0x71,0xE3,0x58,0x30,0xA7,0x20,0x81,0xFD,0xDF,0x66,0xE6,0x5C,0x39,0x8B,0x68,0x44,0xD2,0x00,0x8D,0xFF,0x02,0xBC,0x76,0x0C,0xD8,0x96,0x16,0x96,0xC1,0xC7,0x53,0x86,0xB5,0x2F,0x81,0x4D,0x0B,0x1C,0xBE,0x51,0x01,0xAA,0x66,0x8E,0x9E,0x0F,0x8C,0xDB,0xB8,0x51,0x5F,0xC4,0x43,0xCB,0x82,0x64,0x7F,0xDE,0x4D,0xCD,0x0C,0xDF,0x7F,0x59,0xE6,0xA3,0x76,0x9B,0x01,0x78,0xF1,0x32,0x76,0x84,0x44,0x5B,0x4C,0x4C,0xFC,0xD1,0x15,0xDA,0x53,0xDA,0x7B,0xE2,0x9A,0x03,0xFB,0x45,0x4A,0x61,0xDF,0x6C,0x40,0x62,0xE2,0x49,0xF6,0xB4,0x49,0xDE,0x28,0xC1,0x28,0xCF,0x03,0xF1,0x5B,0x2B,0x0A,0x50,0xDB,0xBB,0x1D,0x88,0x02,0x10,0x6C,0x70,0x86,0x57,0x0F,0x99,0xC3,0x84,0xEB,0x11,0x5D,0xB6,0xC6,0x1C,0x70,0xCD,0xBD,0xC6,0x8C,0xCA,0x2D,0x8C,0xA3,0xE0,0xBB,0x0E,0xD7,0x11,0x22,0x4F,0x33,0x6F,0xDB,0x39,0x6E,0xAA,0x9D,0xEC,0xD1,0xF4,0xAD,0xF7,0xB4,0xE7,0x1C,0x08,0x00,0x38,0x62,0xE5,0x99,0x8B,0x4E,0x64,0x17,0xE9,0xB9,0xE8,0xD1,0xBA,0xAA,0x8C,0x9D,0x57,0xD9,0x22,0xD5,0x2B,0xFC,0x7B,0x86,0x59,0x33,0xE3,0x15,0xF3,0x53,0x67,0xA1,0x6A,0x6C,0xA8,0x47,0x47,0x37,0x3F,0xF1,0xF3,0x43,0xEF,0xC2,0x50,0xE6,0xE3,0x01,0x0A,0x3A,0x30,0x3E,0x4C,0x74,0x68,0xD7,0xCD,0x5A,0x44,0x73,0xE2,0xD8,0x9D,0x86,0x80,0x27,0xB2,0x0F,0xF8,0xA6,0x5F,0xC2,0x8E,0x56,0x3B,0x1F,0x90,0x83,0xBB,0xF8,0xAD,0xC8,0xA2,0x55,0x87,0xAC,0x84,0x64,0xA9,0xCF,0x2A,0x30,0x64,0x15,0x56,0x00,0x49,0x5A,0xDE,0x62,0x54,0x2A,0x87,0x8A,0x3B,0x51,0xE7,0x5B,0xA0,0x24,0x46,0x79,0x13,0x2F,0xCD,0x7C,0x22,0x3B,0x3C,0x52,0x29,0x2A,0x24,0x2C,0x0F,0x83,0x47,0x49,0xB3,0x0F,0x0F,0xD7,0xC8,0x82,0xF1,0x48,0x22,0xD7,0x13,0xF8,0x7F,0xF2,0x4D,0x01,0xA2,0x17,0x89,0x9B,0xD7,0xC7,0x1D,0x24,0xDD,0xA2,0xAD,0x2E,0x30,0x7A,0xCF,0x65,0x09,0x78,0x82,0xD6,0x7D,0xE5,0x56,0xBB,0xFB,0x89,0xDD,0x32,0x91,0x55,0xB8,0xDA,0x34,0xE7,0xF7,0x6E,0x8C,0x7D,0xF7,0x85,0x0D,0x0F,0x8F,0x0D,0xE6,0x67,0xC5,0x03,0xEF,0x71,0x08,0x25,0xA9,0xE7,0x0D,0x2B,0xCF,0x08,0xA2,0x30,0x8F,0x2B,0x13,0xDE,0xE2,0x44,0x7A,0xE1,0xE8,0x22,0x99,0xA8,0xE2,0xDD,0x7D,0x1F,0xE8,0x32,0x6A,0x87,0x52,0xFF,0xCD,0xB6,0x3F,0xD2,0x65,0xCA,0xDE,0xF4,0xC3,0x60,0x11,0x98,0x7D,0x00,0x54,0x33,0x09,0xDA,0x51,0xAC,0x69,0x8E,0x8E,0xFA,0x3C,0x9E,0x4C,0x42,0x5E,0xB7,0xD2,0x8F,0x6E,0x89,0x09,0x07,0x14,0x53,0x01,0x9C,0xB5,0xF1,0x5F,0x0F,0xE1,0x15,0x2E,0x56,0x5E,0x94,0xB4,0x8E,0x35,0x12,0x9D,0x68,0x4C,0x72,0xAF,0x23,0x51,0x01,0x08,0x81,0xE4,0xCA,0x2F,0xB8,0x63,0x95,0x94,0x90,0x73,0x7D,0xF9,0x6A,0x3A,0xF8,0x51,0x23,0xCC,0x5F,0x91,0x8B,0xA0,0x9B,0x35,0x38,0xC2,0x5F,0x8F,0x18,0x6B,0x1D,0x29,0xA3,0x3E,0x2B,0x24,0xD3,0x20,0x41,0x1D,0x42,0xE3,0x8A,0x79,0xC4,0xDD,0x00,0x09,0x33,0x53,0x3C,0xBF,0xA2,0xEC,0x69,0x70,0xE8,0xE2,0x3E,0xB5,0xE4,0xBE,0x7C,0xAA,0x3C,0x06,0xE4,0x35,0x08,0xF0,0xA8,0xF4,0xD1,0xB6,0x37,0x4D,0x3F,0x76,0x22,0xB1,0x64,0x91,0x8A,0x85,0xE8,0x1D,0x90,0xB2,0x3A,0x72,0x13,0xEF,0x53,0x25,0x02};
|
|
const unsigned char sm[] = {0x30,0x6C,0xE5,0xF3,0x2F,0x45,0x82,0xC3,0x50,0x0A,0xF2,0x62,0x01,0x55,0xD3,0xE3,0x71,0xA3,0xF8,0xF8,0xE9,0x7F,0xC2,0xB1,0x22,0x01,0xEF,0x74,0x1C,0x2E,0xDB,0x2A,0xA4,0x06,0xE7,0xE8,0xE5,0x50,0x00,0x16,0x6D,0x17,0x79,0x12,0x3B,0xBD,0xA1,0xEA,0xC9,0x4E,0x37,0x01,0x5C,0xA5,0xA4,0xEB,0xFF,0x19,0xE4,0xC1,0xA4,0xBF,0x97,0x30,0x01,0xB5,0x1F,0x41,0x47,0x5C,0x42,0x45,0x88,0x83,0xDC,0xF7,0x0C,0x00,0x0F,0xD5,0x0A,0x8A,0x81,0x7E,0x14,0xEC,0xD7,0xD1,0x9C,0x53,0x01,0xF2,0xC0,0x58,0x9E,0x87,0xA2,0x26,0xD1,0x25,0x4C,0x3C,0xB2,0x00,0x9E,0xBF,0x2C,0x4A,0xE9,0x90,0x0B,0xA1,0x51,0xFE,0xB4,0x79,0x00,0x5B,0x2C,0xBB,0xE9,0x30,0x71,0xBB,0x4E,0x3F,0xAC,0x2B,0x3C,0x01,0xE7,0x50,0x29,0x4D,0x05,0xCC,0x03,0xDA,0x2E,0xC8,0xF2,0x0F,0x00,0x13,0xE0,0x28,0xCA,0xC0,0x64,0x88,0xDD,0xD5,0xBE,0xF3,0xBD,0x00,0x5D,0xA9,0xBA,0x82,0xD8,0xF2,0xA2,0x14,0xE0,0x87,0x84,0x4C,0x00,0x65,0x80,0x66,0xAA,0x9B,0x23,0x8B,0x33,0x9B,0x36,0x55,0x6B,0x01,0x5F,0x87,0x87,0xBE,0x49,0x32,0xE2,0x8B,0x70,0xEF,0x69,0x47,0x00,0x1A,0xF5,0xC0,0xDF,0x52,0xE4,0x13,0x21,0x86,0x2E,0x81,0x36,0x00,0x00,0x69,0x01,0x8C,0x3F,0xEB,0x9F,0xAC,0x4D,0xCF,0x6F,0x4B,0x85,0x2C,0x8D,0x42,0xF7,0xA6,0xF0,0xB8,0xA6,0x22,0xFE,0xBC,0x42,0x22,0x00,0x01,0xB0,0x74,0x5E,0x9F,0x8D,0x6E,0x8A,0x54,0xCE,0x67,0x03,0x08,0x01,0xF5,0x6F,0xA9,0xFE,0x51,0xB5,0x12,0xAF,0x06,0xFC,0x50,0xF9,0xEC,0x0A,0xD8,0x1C,0x4D,0x8D,0x73,0x4F,0xCB,0xFB,0xEA,0xDE,0x3D,0x3F,0x8A,0x03,0x9F,0xAA,0x2A,0x2C,0x99,0x57,0xE8,0x35,0xAD,0x55,0xB2,0x2E,0x75,0xBF,0x57,0xBB,0x55,0x6A,0xC8};
|
|
const unsigned char msg[] = {0xD8,0x1C,0x4D,0x8D,0x73,0x4F,0xCB,0xFB,0xEA,0xDE,0x3D,0x3F,0x8A,0x03,0x9F,0xAA,0x2A,0x2C,0x99,0x57,0xE8,0x35,0xAD,0x55,0xB2,0x2E,0x75,0xBF,0x57,0xBB,0x55,0x6A,0xC8};
|
|
const unsigned long long mlen = 33;
|
|
#elif CRYPTO_PUBLICKEYBYTES == 128
|
|
const unsigned char pk[] = {0x6A,0x93,0x02,0xB5,0x1F,0x65,0xAC,0x67,0xC5,0x74,0xA0,0x5E,0x95,0x98,0x60,0x4D,0x95,0xAA,0x6E,0x3C,0x61,0xB9,0x3C,0xBA,0x98,0xEE,0xFE,0x80,0x89,0x05,0x65,0x2D,0x43,0x93,0x3D,0xC0,0xEC,0xEF,0x7B,0xE2,0x67,0x37,0x3E,0xB1,0xAC,0x61,0xD4,0xA9,0x11,0x38,0xD2,0x35,0xF7,0xBA,0x19,0xDD,0x12,0xE5,0x5F,0x48,0xD6,0xFE,0x1E,0x00,0x0A,0xAC,0xB9,0x0A,0xB4,0xFF,0xC3,0xD9,0x0D,0x79,0x3F,0x2A,0x12,0x91,0xDC,0x63,0x8F,0x80,0x28,0xE3,0x1F,0x7D,0xA9,0xFE,0x49,0x76,0x71,0xDB,0x2D,0xBA,0xC7,0x89,0x48,0x6A,0x61,0xC9,0x4B,0xCB,0xE9,0xA8,0xDD,0xD7,0x86,0x70,0x95,0x5C,0xFC,0x3A,0x10,0x4D,0x21,0x41,0x18,0x89,0x12,0x5A,0x96,0x68,0x59,0x1B,0x16,0xD4,0x04,0x00};
|
|
const unsigned char sk[] = {0x6A,0x93,0x02,0xB5,0x1F,0x65,0xAC,0x67,0xC5,0x74,0xA0,0x5E,0x95,0x98,0x60,0x4D,0x95,0xAA,0x6E,0x3C,0x61,0xB9,0x3C,0xBA,0x98,0xEE,0xFE,0x80,0x89,0x05,0x65,0x2D,0x43,0x93,0x3D,0xC0,0xEC,0xEF,0x7B,0xE2,0x67,0x37,0x3E,0xB1,0xAC,0x61,0xD4,0xA9,0x11,0x38,0xD2,0x35,0xF7,0xBA,0x19,0xDD,0x12,0xE5,0x5F,0x48,0xD6,0xFE,0x1E,0x00,0x0A,0xAC,0xB9,0x0A,0xB4,0xFF,0xC3,0xD9,0x0D,0x79,0x3F,0x2A,0x12,0x91,0xDC,0x63,0x8F,0x80,0x28,0xE3,0x1F,0x7D,0xA9,0xFE,0x49,0x76,0x71,0xDB,0x2D,0xBA,0xC7,0x89,0x48,0x6A,0x61,0xC9,0x4B,0xCB,0xE9,0xA8,0xDD,0xD7,0x86,0x70,0x95,0x5C,0xFC,0x3A,0x10,0x4D,0x21,0x41,0x18,0x89,0x12,0x5A,0x96,0x68,0x59,0x1B,0x16,0xD4,0x04,0x00,0x02,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x1C,0xCB,0x52,0xB5,0x61,0x25,0x56,0xF9,0x2A,0x5E,0x3D,0x5D,0xBF,0x4D,0xF3,0x3E,0xA4,0xB3,0x78,0x5A,0x6A,0xA6,0xF7,0xDA,0xF7,0x9F,0x5C,0x5F,0xC8,0x63,0x27,0x5D,0x2F,0xBC,0xFE,0x4A,0x88,0x32,0x3B,0x0F,0x24,0xF8,0x48,0x0C,0x93,0x8F,0xA7,0xDD,0x40,0x3F,0xDA,0x74,0xF7,0x86,0x4F,0x3A,0x3E,0xE6,0xF7,0x87,0x05,0x12,0x78,0xB5,0xFD,0x7E,0x2E,0xF1,0xA9,0xC4,0xD6,0x4C,0x8B,0x5F,0x8A,0x9A,0x99,0x09,0x6A,0x1E,0xF1,0x68,0x32,0x6C,0xE8,0xE1,0x12,0x21,0x44,0x05,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xC3,0x39,0xA9,0xC8,0x3E,0xB9,0x6D,0x9C,0xC2,0xD7,0x7A,0xE8,0x33,0xB3,0x01,0x26,0x7C,0x3E,0x8E,0x59,0x2C,0x19,0x65,0x92,0x35,0x84,0xF9,0x50,0x04,0x95,0x2E,0x69,0xD6,0x34,0x30,0x5E,0x4F,0x50,0xCE,0x7F,0xBD,0x89,0xE4,0x93,0x18,0x98,0x6B,0x0F,0x1F,0xA1,0xDB,0xBA,0xE1,0x7C,0x59,0x22,0x29,0x87,0x00,0x8A,0x1F,0x67,0x94,0x27,0xDA,0x64,0x5B,0xFC,0xE9,0x00,0x6C,0x68,0x15,0xE1,0x90,0x38,0xE6,0x10,0x3B,0x81,0x13,0xC2,0x58,0x7D,0xD4,0x21,0x15,0x32,0x91,0xE8,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xDB,0xE8,0xB4,0x7E,0xF0,0x4B,0x4E,0x0C,0x60,0x64,0x91,0x4B,0x85,0x8D,0xAC,0x47,0x56,0xAA,0x2C,0x89,0xD6,0x28,0xFD,0x56,0xAA,0x84,0xDD,0xBB,0xDD,0x33,0xB7,0xA8,0x48,0x5E,0xAA,0x43,0x6B,0x20,0x1A,0xFC,0x1B,0x9F,0x8A,0xEB,0xDE,0x42,0xD3,0xD8,0x96,0x20,0xB0,0x3D,0xC4,0x30,0x81,0x91,0xED,0x41,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x98,0x9F,0xA7,0xFA,0xCE,0xC9,0x8A,0xC6,0xFB,0x9E,0x4E,0x6A,0x3B,0x49,0xC4,0x4E,0xB8,0x29,0x29,0x61,0x5C,0xBA,0x18,0xD3,0xEF,0x33,0x51,0xE0,0xDA,0x72,0x0E,0xCB,0x37,0x6E,0xE1,0x4A,0x5E,0x86,0x88,0xB5,0x76,0x5E,0x24,0x1D,0xD1,0xC0,0x8A,0xC7,0x60,0x8D,0xCA,0x19,0xFB,0xB2,0x6B,0x58,0x9C,0x42,0x02,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xA7,0x8B,0x0B,0xD3,0xAE,0x6D,0xBE,0x94,0x79,0x68,0x7E,0x49,0x6A,0x2F,0x81,0x52,0x79,0x1D,0xFD,0x83,0x4E,0xE2,0x59,0xEA,0x6A,0xE9,0x46,0xFE,0x37,0x2A,0xD2,0x82,0xA4,0xCA,0xCF,0x7B,0x22,0x13,0xBC,0x3D,0x86,0x1D,0x57,0x8E,0x89,0xE4,0x15,0xFD,0xF0,0x72,0x42,0x02,0x29,0x47,0x29,0x45,0xF2,0x03,0x6D,0x07,0x23,0xE4,0x23,0x00,0x66,0x7E,0x8A,0xA1,0xD7,0x6A,0x14,0x20,0x5A,0xAA,0x1D,0x62,0x18,0xCC,0x6C,0xD6,0x77,0x50,0x92,0xFB,0x13,0x66,0x80,0x42,0x84,0xC1,0x15,0x57,0x1E,0xAD,0x08,0x8E,0xAB,0xC5,0x3F,0xA7,0xA8,0x05,0x90,0x1F,0x97,0x9D,0x71,0x7F,0x0D,0xD8,0xF3,0x14,0x5B,0xCB,0xD1,0x71,0x2D,0xF5,0x03,0x9E,0xB4,0xED,0x56,0xCD,0xBD,0x53,0x04,0x00,0x45,0xFC,0x83,0x04,0x9C,0x31,0xB1,0x34,0x6A,0x7F,0xA5,0x4B,0x2D,0x82,0x00,0xE0,0x95,0xAA,0x80,0x89,0x2F,0xB9,0xA3,0x97,0xA6,0xE2,0x1B,0xCD,0x3C,0x66,0x21,0x33,0x1B,0x7E,0x56,0x0B,0xA4,0x6F,0x25,0xB0,0xB3,0x55,0x69,0x7F,0xF1,0x99,0x02,0xF1,0xB6,0xA1,0x9C,0x3C,0xC3,0x0E,0x58,0x3A,0x21,0x15,0xFB,0x5B,0x1C,0xBC,0x05,0x00,0x9A,0xB6,0x21,0x59,0x26,0xF0,0x90,0x69,0x5A,0x9D,0x14,0xB0,0xCC,0x49,0x53,0x82,0x49,0xCE,0xF9,0x8A,0x79,0x47,0x1B,0xA4,0x1D,0xA0,0x45,0xCA,0xD2,0x7C,0x88,0xC8,0xFD,0x13,0x25,0x16,0x37,0x5F,0xAF,0xAD,0x91,0x13,0x76,0x11,0x75,0xF5,0x0F,0xA2,0x5E,0x1A,0x1C,0x47,0x3C,0xD3,0x3A,0xC8,0x43,0x26,0x8C,0x51,0x5E,0x25,0x20,0x00,0x11,0x70,0x1B,0x05,0x0A,0x20,0x1A,0x78,0x62,0x9D,0x43,0x43,0xBE,0x85,0x74,0x32,0x67,0x58,0x07,0x2C,0xBA,0xDA,0x17,0x14,0xA2,0x17,0x94,0x50,0x2A,0xE7,0x84,0x6A,0xF7,0x3F,0x1C,0x6B,0xD7,0x61,0x81,0x89,0xF6,0x8E,0xBE,0x5C,0x60,0x2E,0x44,0x67,0xDD,0x19,0xA7,0x75,0x13,0x01,0x99,0x38,0x10,0x3A,0x96,0x30,0xBC,0x0A,0x17,0x00,0x1E,0xBA,0x74,0x17,0xCC,0x5E,0x4F,0xAC,0x4A,0x5D,0xBD,0x52,0xAC,0x5A,0x22,0x63,0xBB,0x5F,0xF5,0x5F,0xE2,0xDA,0x2F,0x4E,0x6D,0xC4,0xB3,0xE9,0x24,0x46,0x9F,0x33,0x45,0x63,0xB2,0x4C,0x5F,0xF0,0xC5,0x20,0x7A,0x57,0xA6,0xF2,0x69,0x88,0x46,0x9B,0x09,0xD4,0xBD,0x75,0x83,0xA3,0xB1,0x36,0x95,0xB7,0x9A,0xCC,0x75,0xDE,0x09,0x00,0xC6,0x16,0xAA,0xC1,0x53,0x2A,0x88,0xD9,0x61,0xA1,0x70,0x29,0xE8,0xD5,0x1E,0xB6,0x6A,0x64,0x31,0x41,0x1B,0xA3,0x83,0x6F,0xF7,0x75,0x27,0x75,0xF4,0xCE,0xB1,0x41,0xAA,0x99,0x0E,0xDD,0xA2,0xCC,0x84,0x30,0x16,0x5D,0x27,0x21,0x6A,0x40,0x62,0x48,0xAA,0x94,0x6A,0x17,0xDF,0x85,0x06,0xDE,0x49,0xC4,0xF6,0x15,0x56,0xD2,0x21,0x00,0x79,0x52,0xC2,0x4E,0x3F,0xAC,0x50,0xCD,0x59,0x04,0x36,0x6B,0x4B,0x6B,0xA5,0x7E,0x17,0xC5,0xF1,0xCA,0x5E,0x31,0x37,0x50,0xCE,0x09,0x1D,0xF1,0x6B,0xEE,0x1C,0x3C,0xA5,0x99,0x8B,0xE1,0xBD,0x26,0xE2,0x68,0x79,0x38,0x31,0x2B,0xCC,0xD3,0x01,0xFB,0xA2,0x71,0x6E,0xB9,0x31,0x71,0x53,0x65,0x19,0x9A,0xA0,0xE0,0x73,0xB0,0x04,0x00,0x85,0xF5,0xA3,0x51,0xDE,0x09,0xC6,0xE4,0x74,0xF3,0x1A,0x90,0xBB,0x35,0xE8,0x2A,0xD3,0xCB,0x80,0x2C,0x86,0x30,0xD8,0x74,0xE0,0x70,0x9D,0xD6,0x63,0x22,0x9C,0xC6,0x6E,0xCA,0x49,0x7E,0x33,0x2B,0x56,0xAB,0xAA,0x96,0xB1,0xD7,0x02,0x64,0xFF,0xF1,0xEC,0x0A,0xF6,0x69,0x1E,0x60,0x0B,0xB6,0x1F,0x75,0x6E,0x78,0xE0,0x76,0x0D,0x00,0x0E,0x0E,0x36,0x04,0x04,0x7C,0x33,0x89,0x8F,0xC3,0x92,0xEF,0x55,0x03,0x30,0xF6,0x4C,0x40,0x08,0x57,0x96,0xEB,0x6E,0x8C,0x94,0x2F,0xDF,0xBE,0xC1,0xEB,0x86,0x7E,0x4B,0xCB,0x3D,0x65,0xF7,0x92,0xC4,0xE5,0x02,0x23,0xBB,0x3F,0x55,0xCE,0x81,0x9A,0xED,0xA9,0x7D,0xC4,0x83,0xB0,0x14,0xA2,0x2E,0xE5,0xC7,0x6D,0xA4,0xB8,0x13,0x00,0x84,0xAB,0x87,0xD6,0xFF,0xC5,0x9A,0xA0,0x7A,0x38,0x8E,0xA4,0xD0,0xF8,0x61,0x9D,0xD1,0x21,0x8A,0xF2,0xC3,0xDD,0xA9,0xBF,0x2F,0x0C,0x70,0x47,0x31,0x8B,0x64,0x8E,0xF0,0x80,0x1C,0x42,0x5D,0x47,0x6C,0xF3,0xB5,0x7F,0xE7,0xD6,0x5D,0x94,0x5D,0xA1,0xB4,0x4F,0xC1,0xE3,0x14,0xC9,0xFF,0x1C,0x42,0x9D,0x64,0x3E,0x2F,0x23,0x10,0x00,0x57,0xF1,0x12,0xB3,0xF5,0xEC,0x14,0x0F,0x7D,0x2E,0x15,0x08,0x6E,0x81,0xD0,0x8A,0x1B,0xD9,0x95,0x6C,0xCE,0xEC,0x69,0xA4,0x36,0x5D,0xAF,0x0A,0x63,0xA6,0x80,0x77,0xB4,0xEC,0xD9,0x11,0xC0,0x05,0x65,0x10,0xB4,0xB2,0xBC,0x92,0x45,0x9E,0x77,0xCF,0x7D,0xDD,0x63,0x22,0xC0,0xA9,0x12,0x82,0xAF,0x30,0x9A,0x1B,0xE0,0xE7,0x0E,0x00,0xA8,0xD4,0x22,0x94,0x17,0x36,0x34,0xD0,0x69,0x84,0x14,0x08,0xEE,0x4C,0x5C,0x3B,0x35,0xBE,0xE5,0x12,0xBC,0x56,0xCF,0x7C,0x41,0x8C,0xFF,0x86,0x17,0xC8,0x46,0x39,0xB0,0x3D,0x57,0xD0,0x29,0xC3,0xE8,0xD6,0x17,0xCF,0x19,0x82,0x46,0xE0,0xF5,0x13,0xDC,0x5E,0x66,0x7D,0x9B,0xCC,0x90,0xF2,0x0F,0x9F,0xB7,0x21,0x41,0xCC,0x0C,0x00,0x90,0xF2,0x4B,0xD2,0xA9,0x00,0xD2,0x5D,0x90,0x13,0xA3,0x70,0x19,0x1F,0xA8,0x8D,0x18,0xA1,0x3A,0x90,0xD1,0x34,0x46,0x88,0xD3,0xAB,0xE4,0x5D,0xE6,0xA6,0xC0,0x64,0x7F,0x92,0xDE,0x0E,0xF0,0x43,0x46,0x00,0x02,0x64,0xA5,0x46,0x34,0x54,0xF6,0x59,0xCC,0x41,0xD8,0x42,0x78,0x23,0x36,0x37,0x26,0x95,0x9A,0x96,0xD5,0x91,0x15,0x00};
|
|
const unsigned char sm[] = {0xD3,0x3B,0xF0,0xF0,0x83,0xFF,0x80,0xC0,0x02,0x1E,0xBB,0x85,0xF0,0xAA,0x03,0x4D,0x1A,0x5F,0x00,0xFD,0xE6,0xB7,0x50,0x2C,0x9B,0x50,0x00,0x15,0xAD,0x7D,0x75,0x2B,0x3E,0x47,0xD2,0x4A,0x45,0x01,0xD4,0xAC,0x85,0x0B,0xB4,0x3C,0xA4,0xA9,0x85,0x76,0x6D,0x48,0x56,0x9D,0xD2,0x68,0x1C,0x51,0x00,0x09,0xF5,0x73,0xE2,0xD4,0x6A,0x85,0x89,0xE6,0x06,0x95,0x09,0x79,0x9D,0x16,0xC2,0xA4,0xF1,0x01,0xEE,0x26,0x0B,0x7B,0xE5,0x5D,0x11,0x1F,0x7E,0xA7,0x08,0x75,0xA9,0x1D,0x05,0xC4,0x8B,0x13,0x00,0x75,0xE4,0x61,0x77,0x99,0x1D,0x74,0x6C,0x20,0xC2,0xFB,0x27,0xF8,0x99,0xA9,0xD4,0x04,0x5A,0x01,0x64,0xC7,0x68,0x2B,0x46,0x5F,0x4A,0x7B,0x53,0xAD,0xF1,0xF1,0xF4,0xBC,0x91,0x9E,0xF0,0x3E,0x00,0x62,0x54,0xCC,0xF4,0x1B,0x5F,0x6D,0x67,0x8E,0x17,0x65,0x2C,0xD6,0x3E,0xA6,0xC1,0x83,0xF3,0x01,0xBC,0x58,0xFC,0x44,0xC2,0x4A,0x70,0x79,0x9F,0x3A,0xFF,0xF2,0xF6,0x29,0x70,0xBA,0x7E,0x6F,0x01,0xD0,0x5A,0x2A,0x85,0x83,0x68,0x5B,0x7C,0xD7,0x55,0x6E,0x46,0xC3,0x89,0x93,0x36,0x1E,0xA2,0x01,0x91,0x78,0x7E,0x26,0x07,0x81,0x05,0xC0,0xBD,0x3B,0x54,0x09,0xFF,0xDA,0x68,0x42,0x40,0x14,0x01,0x97,0x22,0x89,0x58,0xA0,0x75,0x00,0x09,0xD5,0x48,0x21,0x59,0xA4,0x53,0x58,0x59,0x4F,0xFF,0x01,0xE9,0x2C,0x17,0xD5,0xF6,0x47,0xB3,0xE2,0x70,0xA3,0xCD,0x06,0xCB,0x0E,0xCD,0x2B,0x53,0x18,0x00,0x86,0xAE,0xFA,0x2B,0x45,0x41,0xDA,0xDF,0x76,0x50,0xD1,0x17,0x45,0x55,0x4B,0x5E,0xA2,0x28,0x00,0x01,0x1B,0x9E,0xFD,0xCE,0xAB,0x91,0x43,0xF9,0xF6,0x27,0x9E,0x01,0xFF,0x54,0x17,0xA4,0x76,0x66,0x85,0x7B,0x98,0x59,0xD7,0x31,0x64,0x04,0xC0,0x24,0xBF,0x26,0x8A,0x88,0x08,0x03,0x41,0x5B,0x47,0x97,0xE9,0x69,0x08,0x8E,0xD5,0xB3,0x46,0x53,0x09,0xBD,0xA6,0xDC,0xBC,0x5F,0x00,0x7E,0xD0,0xA3,0x2B,0xA4,0x3A,0xFA,0xB0,0x51,0x47,0x2F,0x3F,0xF0,0x79,0x03,0xD8,0x1C,0x4D,0x8D,0x73,0x4F,0xCB,0xFB,0xEA,0xDE,0x3D,0x3F,0x8A,0x03,0x9F,0xAA,0x2A,0x2C,0x99,0x57,0xE8,0x35,0xAD,0x55,0xB2,0x2E,0x75,0xBF,0x57,0xBB,0x55,0x6A,0xC8};
|
|
const unsigned char msg[] = {0xD8,0x1C,0x4D,0x8D,0x73,0x4F,0xCB,0xFB,0xEA,0xDE,0x3D,0x3F,0x8A,0x03,0x9F,0xAA,0x2A,0x2C,0x99,0x57,0xE8,0x35,0xAD,0x55,0xB2,0x2E,0x75,0xBF,0x57,0xBB,0x55,0x6A,0xC8};
|
|
const unsigned long long mlen = 33;
|
|
#else
|
|
#error "Not supported"
|
|
#endif
|
|
|
|
static int test_sqisign_keygen() {
|
|
int res = 0;
|
|
unsigned char *pk = calloc(CRYPTO_PUBLICKEYBYTES, 1);
|
|
unsigned char *sk = calloc(CRYPTO_SECRETKEYBYTES, 1);
|
|
|
|
res = sqisign_keypair(pk, sk);
|
|
if (res != 0) {
|
|
res = -1;
|
|
}
|
|
|
|
free(pk);
|
|
free(sk);
|
|
return 0;
|
|
}
|
|
|
|
static int test_sqisign_sign(int mlen) {
|
|
int res = 0;
|
|
unsigned char *sig = calloc(CRYPTO_BYTES + mlen, 1);
|
|
unsigned long long smlen = CRYPTO_BYTES + mlen;
|
|
|
|
res = sqisign_sign(sig, &smlen, msg, mlen, sk);
|
|
if (res != 0) {
|
|
res = -1;
|
|
}
|
|
|
|
free(sig);
|
|
return res;
|
|
}
|
|
|
|
|
|
static int test_sqisign_open(int mlen) {
|
|
int res = 0;
|
|
unsigned long long msglen = mlen;
|
|
unsigned char *msg = calloc(mlen, 1);
|
|
|
|
unsigned long long smlen = CRYPTO_BYTES + mlen;
|
|
|
|
res = sqisign_open(msg, &msglen, sm, smlen, pk);
|
|
if (res != 0) {
|
|
res = -1;
|
|
}
|
|
|
|
|
|
free(msg);
|
|
return res;
|
|
}
|
|
|
|
|
|
int main(int argc, char *argv[]) {
|
|
int rc = 0;
|
|
|
|
if (argc <= 1) {
|
|
printf("Usage: <0(keygen)/1(sign)/2(open)>\n");
|
|
exit(0);
|
|
}
|
|
|
|
int ar = atoi(argv[1]);
|
|
|
|
if (ar == 0)
|
|
return test_sqisign_keygen();
|
|
else if (ar == 1)
|
|
return test_sqisign_sign(mlen);
|
|
else if (ar == 2)
|
|
return test_sqisign_open(mlen);
|
|
|
|
printf("Usage: <1(keygen)/2(sign)/3(open)>\n");
|
|
return 0;
|
|
}
|