You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

120 lines
3.7KB

  1. /*
  2. * This file is part of FFmpeg.
  3. *
  4. * FFmpeg is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU Lesser General Public
  6. * License as published by the Free Software Foundation; either
  7. * version 2.1 of the License, or (at your option) any later version.
  8. *
  9. * FFmpeg is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. * Lesser General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Lesser General Public
  15. * License along with FFmpeg; if not, write to the Free Software
  16. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  17. */
  18. // LCOV_EXCL_START
  19. #include <string.h>
  20. #include "libavutil/aes.h"
  21. #include "libavutil/lfg.h"
  22. #include "libavutil/log.h"
  23. #include "libavutil/mem.h"
  24. int main(int argc, char **argv)
  25. {
  26. int i, j;
  27. struct AVAES *b;
  28. static const uint8_t rkey[2][16] = {
  29. { 0 },
  30. { 0x10, 0xa5, 0x88, 0x69, 0xd7, 0x4b, 0xe5, 0xa3,
  31. 0x74, 0xcf, 0x86, 0x7c, 0xfb, 0x47, 0x38, 0x59 }
  32. };
  33. static const uint8_t rpt[2][16] = {
  34. { 0x6a, 0x84, 0x86, 0x7c, 0xd7, 0x7e, 0x12, 0xad,
  35. 0x07, 0xea, 0x1b, 0xe8, 0x95, 0xc5, 0x3f, 0xa3 },
  36. { 0 }
  37. };
  38. static const uint8_t rct[2][16] = {
  39. { 0x73, 0x22, 0x81, 0xc0, 0xa0, 0xaa, 0xb8, 0xf7,
  40. 0xa5, 0x4a, 0x0c, 0x67, 0xa0, 0xc4, 0x5e, 0xcf },
  41. { 0x6d, 0x25, 0x1e, 0x69, 0x44, 0xb0, 0x51, 0xe0,
  42. 0x4e, 0xaa, 0x6f, 0xb4, 0xdb, 0xf7, 0x84, 0x65 }
  43. };
  44. uint8_t pt[32];
  45. uint8_t temp[32];
  46. uint8_t iv[2][16];
  47. int err = 0;
  48. b = av_aes_alloc();
  49. if (!b)
  50. return 1;
  51. av_log_set_level(AV_LOG_DEBUG);
  52. for (i = 0; i < 2; i++) {
  53. av_aes_init(b, rkey[i], 128, 1);
  54. av_aes_crypt(b, temp, rct[i], 1, NULL, 1);
  55. for (j = 0; j < 16; j++) {
  56. if (rpt[i][j] != temp[j]) {
  57. av_log(NULL, AV_LOG_ERROR, "%d %02X %02X\n",
  58. j, rpt[i][j], temp[j]);
  59. err = 1;
  60. }
  61. }
  62. }
  63. av_free(b);
  64. if (argc > 1 && !strcmp(argv[1], "-t")) {
  65. struct AVAES *ae, *ad;
  66. AVLFG prng;
  67. ae = av_aes_alloc();
  68. ad = av_aes_alloc();
  69. if (!ae || !ad) {
  70. av_free(ae);
  71. av_free(ad);
  72. return 1;
  73. }
  74. av_aes_init(ae, (const uint8_t*)"PI=3.141592654..", 128, 0);
  75. av_aes_init(ad, (const uint8_t*)"PI=3.141592654..", 128, 1);
  76. av_lfg_init(&prng, 1);
  77. for (i = 0; i < 10000; i++) {
  78. for (j = 0; j < 32; j++)
  79. pt[j] = av_lfg_get(&prng);
  80. for (j = 0; j < 16; j++)
  81. iv[0][j] = iv[1][j] = av_lfg_get(&prng);
  82. {
  83. START_TIMER;
  84. av_aes_crypt(ae, temp, pt, 2, iv[0], 0);
  85. if (!(i & (i - 1)))
  86. av_log(NULL, AV_LOG_ERROR, "%02X %02X %02X %02X\n",
  87. temp[0], temp[5], temp[10], temp[15]);
  88. av_aes_crypt(ad, temp, temp, 2, iv[1], 1);
  89. av_aes_crypt(ae, temp, pt, 2, NULL, 0);
  90. if (!(i & (i - 1)))
  91. av_log(NULL, AV_LOG_ERROR, "%02X %02X %02X %02X\n",
  92. temp[0], temp[5], temp[10], temp[15]);
  93. av_aes_crypt(ad, temp, temp, 2, NULL, 1);
  94. STOP_TIMER("aes");
  95. }
  96. for (j = 0; j < 16; j++) {
  97. if (pt[j] != temp[j]) {
  98. av_log(NULL, AV_LOG_ERROR, "%d %d %02X %02X\n",
  99. i, j, pt[j], temp[j]);
  100. }
  101. }
  102. }
  103. av_free(ae);
  104. av_free(ad);
  105. }
  106. return err;
  107. }
  108. // LCOV_EXCL_STOP