Color Oled(SSD1331) connect to STMicroelectronics Nucleo-F466

Dependencies:   ssd1331

Committer:
kadonotakashi
Date:
Wed Oct 10 00:33:53 2018 +0000
Revision:
0:8fdf9a60065b
how to make mbed librry

Who changed what in which revision?

UserRevisionLine numberNew contents of line
kadonotakashi 0:8fdf9a60065b 1 /*
kadonotakashi 0:8fdf9a60065b 2 * Copyright (c) , Arm Limited and affiliates.
kadonotakashi 0:8fdf9a60065b 3 * SPDX-License-Identifier: Apache-2.0
kadonotakashi 0:8fdf9a60065b 4 *
kadonotakashi 0:8fdf9a60065b 5 * Licensed under the Apache License, Version 2.0 (the "License");
kadonotakashi 0:8fdf9a60065b 6 * you may not use this file except in compliance with the License.
kadonotakashi 0:8fdf9a60065b 7 * You may obtain a copy of the License at
kadonotakashi 0:8fdf9a60065b 8 *
kadonotakashi 0:8fdf9a60065b 9 * http://www.apache.org/licenses/LICENSE-2.0
kadonotakashi 0:8fdf9a60065b 10 *
kadonotakashi 0:8fdf9a60065b 11 * Unless required by applicable law or agreed to in writing, software
kadonotakashi 0:8fdf9a60065b 12 * distributed under the License is distributed on an "AS IS" BASIS,
kadonotakashi 0:8fdf9a60065b 13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
kadonotakashi 0:8fdf9a60065b 14 * See the License for the specific language governing permissions and
kadonotakashi 0:8fdf9a60065b 15 * limitations under the License.
kadonotakashi 0:8fdf9a60065b 16 */
kadonotakashi 0:8fdf9a60065b 17
kadonotakashi 0:8fdf9a60065b 18
kadonotakashi 0:8fdf9a60065b 19 #if !defined(MBEDTLS_CONFIG_FILE)
kadonotakashi 0:8fdf9a60065b 20 #include "mbedtls/config.h"
kadonotakashi 0:8fdf9a60065b 21 #else
kadonotakashi 0:8fdf9a60065b 22 #include MBEDTLS_CONFIG_FILE
kadonotakashi 0:8fdf9a60065b 23 #endif
kadonotakashi 0:8fdf9a60065b 24
kadonotakashi 0:8fdf9a60065b 25 #include <string.h>
kadonotakashi 0:8fdf9a60065b 26
kadonotakashi 0:8fdf9a60065b 27 #include "mbedtls/aes.h"
kadonotakashi 0:8fdf9a60065b 28
kadonotakashi 0:8fdf9a60065b 29 #include "aes_stub.h"
kadonotakashi 0:8fdf9a60065b 30 aes_stub_def aes_stub;
kadonotakashi 0:8fdf9a60065b 31
kadonotakashi 0:8fdf9a60065b 32
kadonotakashi 0:8fdf9a60065b 33 void mbedtls_aes_init( mbedtls_aes_context *ctx )
kadonotakashi 0:8fdf9a60065b 34 {
kadonotakashi 0:8fdf9a60065b 35 }
kadonotakashi 0:8fdf9a60065b 36
kadonotakashi 0:8fdf9a60065b 37 void mbedtls_aes_free( mbedtls_aes_context *ctx )
kadonotakashi 0:8fdf9a60065b 38 {
kadonotakashi 0:8fdf9a60065b 39 }
kadonotakashi 0:8fdf9a60065b 40
kadonotakashi 0:8fdf9a60065b 41 #if defined(MBEDTLS_CIPHER_MODE_XTS)
kadonotakashi 0:8fdf9a60065b 42 void mbedtls_aes_xts_init( mbedtls_aes_xts_context *ctx )
kadonotakashi 0:8fdf9a60065b 43 {
kadonotakashi 0:8fdf9a60065b 44 }
kadonotakashi 0:8fdf9a60065b 45
kadonotakashi 0:8fdf9a60065b 46 void mbedtls_aes_xts_free( mbedtls_aes_xts_context *ctx )
kadonotakashi 0:8fdf9a60065b 47 {
kadonotakashi 0:8fdf9a60065b 48 }
kadonotakashi 0:8fdf9a60065b 49 #endif
kadonotakashi 0:8fdf9a60065b 50
kadonotakashi 0:8fdf9a60065b 51 #if !defined(MBEDTLS_AES_SETKEY_ENC_ALT)
kadonotakashi 0:8fdf9a60065b 52 int mbedtls_aes_setkey_enc( mbedtls_aes_context *ctx, const unsigned char *key,
kadonotakashi 0:8fdf9a60065b 53 unsigned int keybits )
kadonotakashi 0:8fdf9a60065b 54 {
kadonotakashi 0:8fdf9a60065b 55 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 56 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 57 return 0;
kadonotakashi 0:8fdf9a60065b 58 }
kadonotakashi 0:8fdf9a60065b 59 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 60 }
kadonotakashi 0:8fdf9a60065b 61 #endif
kadonotakashi 0:8fdf9a60065b 62
kadonotakashi 0:8fdf9a60065b 63 #if !defined(MBEDTLS_AES_SETKEY_DEC_ALT)
kadonotakashi 0:8fdf9a60065b 64 int mbedtls_aes_setkey_dec( mbedtls_aes_context *ctx, const unsigned char *key,
kadonotakashi 0:8fdf9a60065b 65 unsigned int keybits )
kadonotakashi 0:8fdf9a60065b 66 {
kadonotakashi 0:8fdf9a60065b 67 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 68 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 69 return 0;
kadonotakashi 0:8fdf9a60065b 70 }
kadonotakashi 0:8fdf9a60065b 71 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 72 }
kadonotakashi 0:8fdf9a60065b 73 #endif
kadonotakashi 0:8fdf9a60065b 74
kadonotakashi 0:8fdf9a60065b 75 #if defined(MBEDTLS_CIPHER_MODE_XTS)
kadonotakashi 0:8fdf9a60065b 76 int mbedtls_aes_xts_setkey_enc( mbedtls_aes_xts_context *ctx,
kadonotakashi 0:8fdf9a60065b 77 const unsigned char *key,
kadonotakashi 0:8fdf9a60065b 78 unsigned int keybits)
kadonotakashi 0:8fdf9a60065b 79 {
kadonotakashi 0:8fdf9a60065b 80 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 81 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 82 return 0;
kadonotakashi 0:8fdf9a60065b 83 }
kadonotakashi 0:8fdf9a60065b 84 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 85 }
kadonotakashi 0:8fdf9a60065b 86
kadonotakashi 0:8fdf9a60065b 87 int mbedtls_aes_xts_setkey_dec( mbedtls_aes_xts_context *ctx,
kadonotakashi 0:8fdf9a60065b 88 const unsigned char *key,
kadonotakashi 0:8fdf9a60065b 89 unsigned int keybits)
kadonotakashi 0:8fdf9a60065b 90 {
kadonotakashi 0:8fdf9a60065b 91 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 92 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 93 return 0;
kadonotakashi 0:8fdf9a60065b 94 }
kadonotakashi 0:8fdf9a60065b 95 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 96 }
kadonotakashi 0:8fdf9a60065b 97 #endif
kadonotakashi 0:8fdf9a60065b 98
kadonotakashi 0:8fdf9a60065b 99 int mbedtls_internal_aes_encrypt( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 100 const unsigned char input[16],
kadonotakashi 0:8fdf9a60065b 101 unsigned char output[16] )
kadonotakashi 0:8fdf9a60065b 102 {
kadonotakashi 0:8fdf9a60065b 103 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 104 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 105 return 0;
kadonotakashi 0:8fdf9a60065b 106 }
kadonotakashi 0:8fdf9a60065b 107 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 108 }
kadonotakashi 0:8fdf9a60065b 109
kadonotakashi 0:8fdf9a60065b 110 void mbedtls_aes_encrypt( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 111 const unsigned char input[16],
kadonotakashi 0:8fdf9a60065b 112 unsigned char output[16] )
kadonotakashi 0:8fdf9a60065b 113 {
kadonotakashi 0:8fdf9a60065b 114 }
kadonotakashi 0:8fdf9a60065b 115
kadonotakashi 0:8fdf9a60065b 116 int mbedtls_internal_aes_decrypt( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 117 const unsigned char input[16],
kadonotakashi 0:8fdf9a60065b 118 unsigned char output[16] )
kadonotakashi 0:8fdf9a60065b 119 {
kadonotakashi 0:8fdf9a60065b 120 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 121 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 122 return 0;
kadonotakashi 0:8fdf9a60065b 123 }
kadonotakashi 0:8fdf9a60065b 124 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 125 }
kadonotakashi 0:8fdf9a60065b 126
kadonotakashi 0:8fdf9a60065b 127 void mbedtls_aes_decrypt( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 128 const unsigned char input[16],
kadonotakashi 0:8fdf9a60065b 129 unsigned char output[16] )
kadonotakashi 0:8fdf9a60065b 130 {
kadonotakashi 0:8fdf9a60065b 131 }
kadonotakashi 0:8fdf9a60065b 132
kadonotakashi 0:8fdf9a60065b 133 int mbedtls_aes_crypt_ecb( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 134 int mode,
kadonotakashi 0:8fdf9a60065b 135 const unsigned char input[16],
kadonotakashi 0:8fdf9a60065b 136 unsigned char output[16] )
kadonotakashi 0:8fdf9a60065b 137 {
kadonotakashi 0:8fdf9a60065b 138 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 139 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 140 return 0;
kadonotakashi 0:8fdf9a60065b 141 }
kadonotakashi 0:8fdf9a60065b 142 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 143 }
kadonotakashi 0:8fdf9a60065b 144
kadonotakashi 0:8fdf9a60065b 145 int mbedtls_aes_crypt_cbc( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 146 int mode,
kadonotakashi 0:8fdf9a60065b 147 size_t length,
kadonotakashi 0:8fdf9a60065b 148 unsigned char iv[16],
kadonotakashi 0:8fdf9a60065b 149 const unsigned char *input,
kadonotakashi 0:8fdf9a60065b 150 unsigned char *output )
kadonotakashi 0:8fdf9a60065b 151 {
kadonotakashi 0:8fdf9a60065b 152 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 153 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 154 return 0;
kadonotakashi 0:8fdf9a60065b 155 }
kadonotakashi 0:8fdf9a60065b 156 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 157 }
kadonotakashi 0:8fdf9a60065b 158
kadonotakashi 0:8fdf9a60065b 159
kadonotakashi 0:8fdf9a60065b 160 #if defined(MBEDTLS_CIPHER_MODE_XTS)
kadonotakashi 0:8fdf9a60065b 161 int mbedtls_aes_crypt_xts( mbedtls_aes_xts_context *ctx,
kadonotakashi 0:8fdf9a60065b 162 int mode,
kadonotakashi 0:8fdf9a60065b 163 size_t length,
kadonotakashi 0:8fdf9a60065b 164 const unsigned char data_unit[16],
kadonotakashi 0:8fdf9a60065b 165 const unsigned char *input,
kadonotakashi 0:8fdf9a60065b 166 unsigned char *output )
kadonotakashi 0:8fdf9a60065b 167 {
kadonotakashi 0:8fdf9a60065b 168 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 169 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 170 return 0;
kadonotakashi 0:8fdf9a60065b 171 }
kadonotakashi 0:8fdf9a60065b 172 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 173 }
kadonotakashi 0:8fdf9a60065b 174 #endif
kadonotakashi 0:8fdf9a60065b 175
kadonotakashi 0:8fdf9a60065b 176 int mbedtls_aes_crypt_cfb128( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 177 int mode,
kadonotakashi 0:8fdf9a60065b 178 size_t length,
kadonotakashi 0:8fdf9a60065b 179 size_t *iv_off,
kadonotakashi 0:8fdf9a60065b 180 unsigned char iv[16],
kadonotakashi 0:8fdf9a60065b 181 const unsigned char *input,
kadonotakashi 0:8fdf9a60065b 182 unsigned char *output )
kadonotakashi 0:8fdf9a60065b 183 {
kadonotakashi 0:8fdf9a60065b 184 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 185 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 186 return 0;
kadonotakashi 0:8fdf9a60065b 187 }
kadonotakashi 0:8fdf9a60065b 188 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 189 }
kadonotakashi 0:8fdf9a60065b 190
kadonotakashi 0:8fdf9a60065b 191 int mbedtls_aes_crypt_cfb8( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 192 int mode,
kadonotakashi 0:8fdf9a60065b 193 size_t length,
kadonotakashi 0:8fdf9a60065b 194 unsigned char iv[16],
kadonotakashi 0:8fdf9a60065b 195 const unsigned char *input,
kadonotakashi 0:8fdf9a60065b 196 unsigned char *output )
kadonotakashi 0:8fdf9a60065b 197 {
kadonotakashi 0:8fdf9a60065b 198 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 199 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 200 return 0;
kadonotakashi 0:8fdf9a60065b 201 }
kadonotakashi 0:8fdf9a60065b 202 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 203 }
kadonotakashi 0:8fdf9a60065b 204
kadonotakashi 0:8fdf9a60065b 205 int mbedtls_aes_crypt_ofb( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 206 size_t length,
kadonotakashi 0:8fdf9a60065b 207 size_t *iv_off,
kadonotakashi 0:8fdf9a60065b 208 unsigned char iv[16],
kadonotakashi 0:8fdf9a60065b 209 const unsigned char *input,
kadonotakashi 0:8fdf9a60065b 210 unsigned char *output )
kadonotakashi 0:8fdf9a60065b 211 {
kadonotakashi 0:8fdf9a60065b 212 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 213 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 214 return 0;
kadonotakashi 0:8fdf9a60065b 215 }
kadonotakashi 0:8fdf9a60065b 216 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 217 }
kadonotakashi 0:8fdf9a60065b 218
kadonotakashi 0:8fdf9a60065b 219 int mbedtls_aes_crypt_ctr( mbedtls_aes_context *ctx,
kadonotakashi 0:8fdf9a60065b 220 size_t length,
kadonotakashi 0:8fdf9a60065b 221 size_t *nc_off,
kadonotakashi 0:8fdf9a60065b 222 unsigned char nonce_counter[16],
kadonotakashi 0:8fdf9a60065b 223 unsigned char stream_block[16],
kadonotakashi 0:8fdf9a60065b 224 const unsigned char *input,
kadonotakashi 0:8fdf9a60065b 225 unsigned char *output )
kadonotakashi 0:8fdf9a60065b 226 {
kadonotakashi 0:8fdf9a60065b 227 if (aes_stub.int_zero_counter) {
kadonotakashi 0:8fdf9a60065b 228 aes_stub.int_zero_counter--;
kadonotakashi 0:8fdf9a60065b 229 return 0;
kadonotakashi 0:8fdf9a60065b 230 }
kadonotakashi 0:8fdf9a60065b 231 return aes_stub.int_value;
kadonotakashi 0:8fdf9a60065b 232 }