IxNpeMicrocode.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. /*
  2. * IxNpeMicrocode.h - Headerfile for compiling the Intel microcode C file
  3. *
  4. * Copyright (C) 2006 Christian Hohnstaedt <chohnstaedt@innominate.com>
  5. *
  6. * This file is released under the GPLv2
  7. *
  8. *
  9. * compile with
  10. *
  11. * gcc -Wall IxNpeMicrocode.c -o IxNpeMicrocode
  12. *
  13. * Executing the resulting binary on your build-host creates the
  14. * "NPE-[ABC].xxxxxxxx" files containing the selected microcode
  15. *
  16. * fetch the IxNpeMicrocode.c from the Intel Access Library.
  17. * It will include this header.
  18. *
  19. * select Images for every NPE from the following
  20. * (used C++ comments for easy uncommenting ....)
  21. */
  22. // #define IX_NPEDL_NPEIMAGE_NPEA_ETH_SPAN_MASK_FIREWALL_VLAN_QOS_HDR_CONV_EXTMIB
  23. // #define IX_NPEDL_NPEIMAGE_NPEA_ETH_SPAN_VLAN_QOS_HDR_CONV_EXTMIB
  24. // #define IX_NPEDL_NPEIMAGE_NPEA_ETH_LEARN_FILTER_SPAN_MASK_FIREWALL_VLAN_QOS_EXTMIB
  25. // #define IX_NPEDL_NPEIMAGE_NPEA_HSS_TSLOT_SWITCH
  26. #define IX_NPEDL_NPEIMAGE_NPEA_ETH_SPAN_FIREWALL_VLAN_QOS_HDR_CONV
  27. // #define IX_NPEDL_NPEIMAGE_NPEA_ETH_LEARN_FILTER_SPAN_FIREWALL_VLAN_QOS
  28. // #define IX_NPEDL_NPEIMAGE_NPEA_ETH_LEARN_FILTER_SPAN_FIREWALL
  29. #define IX_NPEDL_NPEIMAGE_NPEA_HSS_2_PORT
  30. // #define IX_NPEDL_NPEIMAGE_NPEA_DMA
  31. // #define IX_NPEDL_NPEIMAGE_NPEA_ATM_MPHY_12_PORT
  32. // #define IX_NPEDL_NPEIMAGE_NPEA_HSS0_ATM_MPHY_1_PORT
  33. // #define IX_NPEDL_NPEIMAGE_NPEA_HSS0_ATM_SPHY_1_PORT
  34. // #define IX_NPEDL_NPEIMAGE_NPEA_HSS0
  35. // #define IX_NPEDL_NPEIMAGE_NPEA_WEP
  36. // #define IX_NPEDL_NPEIMAGE_NPEB_ETH_SPAN_MASK_FIREWALL_VLAN_QOS_HDR_CONV_EXTMIB
  37. // #define IX_NPEDL_NPEIMAGE_NPEB_ETH_SPAN_VLAN_QOS_HDR_CONV_EXTMIB
  38. // #define IX_NPEDL_NPEIMAGE_NPEB_ETH_LEARN_FILTER_SPAN_MASK_FIREWALL_VLAN_QOS_EXTMIB
  39. // #define IX_NPEDL_NPEIMAGE_NPEB_DMA
  40. #define IX_NPEDL_NPEIMAGE_NPEB_ETH_SPAN_FIREWALL_VLAN_QOS_HDR_CONV
  41. // #define IX_NPEDL_NPEIMAGE_NPEB_ETH_LEARN_FILTER_SPAN_FIREWALL_VLAN_QOS
  42. // #define IX_NPEDL_NPEIMAGE_NPEB_ETH_LEARN_FILTER_SPAN_FIREWALL
  43. // #define IX_NPEDL_NPEIMAGE_NPEC_ETH_SPAN_MASK_FIREWALL_VLAN_QOS_HDR_CONV_EXTMIB
  44. // #define IX_NPEDL_NPEIMAGE_NPEC_ETH_SPAN_VLAN_QOS_HDR_CONV_EXTMIB
  45. // #define IX_NPEDL_NPEIMAGE_NPEC_ETH_LEARN_FILTER_SPAN_MASK_FIREWALL_VLAN_QOS_EXTMIB
  46. // #define IX_NPEDL_NPEIMAGE_NPEC_DMA
  47. // #define IX_NPEDL_NPEIMAGE_NPEC_CRYPTO_AES_ETH_LEARN_FILTER_SPAN
  48. // #define IX_NPEDL_NPEIMAGE_NPEC_CRYPTO_AES_ETH_LEARN_FILTER_FIREWALL
  49. #define IX_NPEDL_NPEIMAGE_NPEC_CRYPTO_AES_CCM_ETH
  50. // #define IX_NPEDL_NPEIMAGE_NPEC_CRYPTO_AES_CCM_EXTSHA_ETH
  51. // #define IX_NPEDL_NPEIMAGE_NPEC_CRYPTO_ETH_LEARN_FILTER_SPAN_FIREWALL
  52. // #define IX_NPEDL_NPEIMAGE_NPEC_ETH_SPAN_FIREWALL_VLAN_QOS_HDR_CONV
  53. // #define IX_NPEDL_NPEIMAGE_NPEC_ETH_LEARN_FILTER_SPAN_FIREWALL_VLAN_QOS
  54. // #define IX_NPEDL_NPEIMAGE_NPEC_ETH_LEARN_FILTER_SPAN_FIREWALL
  55. #include <stdio.h>
  56. #include <unistd.h>
  57. #include <stdlib.h>
  58. #include <netinet/in.h>
  59. #include <sys/types.h>
  60. #include <sys/stat.h>
  61. #include <fcntl.h>
  62. #include <errno.h>
  63. #include <endian.h>
  64. #include <byteswap.h>
  65. #include <string.h>
  66. #if __BYTE_ORDER == __LITTLE_ENDIAN
  67. #define to_le32(x) (x)
  68. #define to_be32(x) bswap_32(x)
  69. #else
  70. #define to_be32(x) (x)
  71. #define to_le32(x) bswap_32(x)
  72. #endif
  73. struct dl_image {
  74. unsigned magic;
  75. unsigned id;
  76. unsigned size;
  77. unsigned data[0];
  78. };
  79. const unsigned IxNpeMicrocode_array[];
  80. int main(int argc, char *argv[])
  81. {
  82. struct dl_image *image = (struct dl_image *)IxNpeMicrocode_array;
  83. int imgsiz, i, fd, cnt;
  84. const unsigned *arrayptr = IxNpeMicrocode_array;
  85. const char *names[] = { "IXP425", "IXP465", "unknown" };
  86. int bigendian = 1;
  87. if (argc > 1) {
  88. if (!strcmp(argv[1], "-le"))
  89. bigendian = 0;
  90. else if (!strcmp(argv[1], "-be"))
  91. bigendian = 1;
  92. else {
  93. printf("Usage: %s <-le|-be>\n", argv[0]);
  94. return EXIT_FAILURE;
  95. }
  96. }
  97. for (image = (struct dl_image *)arrayptr, cnt=0;
  98. (image->id != 0xfeedf00d) && (image->magic == 0xfeedf00d);
  99. image = (struct dl_image *)(arrayptr), cnt++)
  100. {
  101. unsigned char field[4];
  102. imgsiz = image->size + 3;
  103. *(unsigned*)field = to_be32(image->id);
  104. char filename[40], slnk[10];
  105. sprintf(filename, "NPE-%c.%08x", (field[0] & 0xf) + 'A',
  106. image->id);
  107. if (image->id == 0x00090000)
  108. sprintf(slnk, "NPE-%c-HSS", (field[0] & 0xf) + 'A');
  109. else
  110. sprintf(slnk, "NPE-%c", (field[0] & 0xf) + 'A');
  111. printf("Writing image: %s.NPE_%c Func: %2x Rev: %02x.%02x "
  112. "Size: %5d to: '%s'\n",
  113. names[field[0] >> 4], (field[0] & 0xf) + 'A',
  114. field[1], field[2], field[3], imgsiz*4, filename);
  115. fd = open(filename, O_CREAT | O_RDWR | O_TRUNC, 0644);
  116. if (fd >= 0) {
  117. for (i=0; i<imgsiz; i++) {
  118. *(unsigned*)field = bigendian ?
  119. to_be32(arrayptr[i]) :
  120. to_le32(arrayptr[i]);
  121. write(fd, field, sizeof(field));
  122. }
  123. close(fd);
  124. unlink(slnk);
  125. symlink(filename, slnk);
  126. } else {
  127. perror(filename);
  128. }
  129. arrayptr += imgsiz;
  130. }
  131. close(fd);
  132. return 0;
  133. }