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.

pnm_test.c 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  1. /*
  2. * Copyright (C) 2013 Michael Brown <mbrown@fensystems.co.uk>.
  3. *
  4. * This program is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU General Public License as
  6. * published by the Free Software Foundation; either version 2 of the
  7. * License, or any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful, but
  10. * WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. * General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program; if not, write to the Free Software
  16. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  17. * 02110-1301, USA.
  18. */
  19. FILE_LICENCE ( GPL2_OR_LATER );
  20. /** @file
  21. *
  22. * PNM self-tests
  23. *
  24. */
  25. /* Forcibly enable assertions */
  26. #undef NDEBUG
  27. #include <string.h>
  28. #include <assert.h>
  29. #include <ipxe/pixbuf.h>
  30. #include <ipxe/pnm.h>
  31. #include <ipxe/test.h>
  32. /** Define inline pixel data */
  33. #define DATA(...) { __VA_ARGS__ }
  34. /** A PNM test */
  35. struct pnm_test {
  36. /** Source image */
  37. struct image *image;
  38. /** Pixel data */
  39. const uint32_t *data;
  40. /** Length of pixel data */
  41. size_t len;
  42. /** Width */
  43. unsigned int width;
  44. /** Height */
  45. unsigned int height;
  46. };
  47. /** Define a PNM test */
  48. #define PNM( NAME, FILE, WIDTH, HEIGHT, DATA ) \
  49. static const char NAME ## _file[] = FILE; \
  50. static const uint32_t NAME ## _data[] = DATA; \
  51. static struct image NAME ## _image = { \
  52. .refcnt = REF_INIT ( ref_no_free ), \
  53. .name = #NAME, \
  54. .data = ( userptr_t ) ( NAME ## _file ), \
  55. .len = sizeof ( NAME ## _file ), \
  56. }; \
  57. static struct pnm_test NAME = { \
  58. .image = & NAME ## _image, \
  59. .data = NAME ## _data, \
  60. .len = sizeof ( NAME ## _data ), \
  61. .width = WIDTH, \
  62. .height = HEIGHT, \
  63. };
  64. /** PBM ASCII example (from Wikipedia) */
  65. PNM ( pbm_ascii,
  66. "P1\n"
  67. "# This is an example bitmap of the letter \"J\"\n"
  68. "6 10\n"
  69. "0 0 0 0 1 0\n"
  70. "0 0 0 0 1 0\n"
  71. "0 0 0 0 1 0\n"
  72. "0 0 0 0 1 0\n"
  73. "0 0 0 0 1 0\n"
  74. "0 0 0 0 1 0\n"
  75. "1 0 0 0 1 0\n"
  76. "0 1 1 1 0 0\n"
  77. "0 0 0 0 0 0\n"
  78. "0 0 0 0 0 0\n",
  79. 6, 10,
  80. DATA ( 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  81. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  82. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  83. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  84. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  85. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  86. 0x000000, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  87. 0xffffff, 0x000000, 0x000000, 0x000000, 0xffffff, 0xffffff,
  88. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0xffffff,
  89. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0xffffff ) );
  90. /** PGM ASCII example (from Wikipedia) */
  91. PNM ( pgm_ascii,
  92. "P2\n"
  93. "# Shows the word \"FEEP\" (example from Netpbm man page on PGM)\n"
  94. "24 7\n"
  95. "15\n"
  96. "0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\n"
  97. "0 3 3 3 3 0 0 7 7 7 7 0 0 11 11 11 11 0 0 15 15 15 15 0\n"
  98. "0 3 0 0 0 0 0 7 0 0 0 0 0 11 0 0 0 0 0 15 0 0 15 0\n"
  99. "0 3 3 3 0 0 0 7 7 7 0 0 0 11 11 11 0 0 0 15 15 15 15 0\n"
  100. "0 3 0 0 0 0 0 7 0 0 0 0 0 11 0 0 0 0 0 15 0 0 0 0\n"
  101. "0 3 0 0 0 0 0 7 7 7 7 0 0 11 11 11 11 0 0 15 0 0 0 0\n"
  102. "0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\n"
  103. , 24, 7,
  104. DATA ( 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  105. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  106. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  107. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  108. 0x000000, 0x333333, 0x333333, 0x333333, 0x333333, 0x000000,
  109. 0x000000, 0x777777, 0x777777, 0x777777, 0x777777, 0x000000,
  110. 0x000000, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0x000000,
  111. 0x000000, 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000,
  112. 0x000000, 0x333333, 0x000000, 0x000000, 0x000000, 0x000000,
  113. 0x000000, 0x777777, 0x000000, 0x000000, 0x000000, 0x000000,
  114. 0x000000, 0xbbbbbb, 0x000000, 0x000000, 0x000000, 0x000000,
  115. 0x000000, 0xffffff, 0x000000, 0x000000, 0xffffff, 0x000000,
  116. 0x000000, 0x333333, 0x333333, 0x333333, 0x000000, 0x000000,
  117. 0x000000, 0x777777, 0x777777, 0x777777, 0x000000, 0x000000,
  118. 0x000000, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0x000000, 0x000000,
  119. 0x000000, 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000,
  120. 0x000000, 0x333333, 0x000000, 0x000000, 0x000000, 0x000000,
  121. 0x000000, 0x777777, 0x000000, 0x000000, 0x000000, 0x000000,
  122. 0x000000, 0xbbbbbb, 0x000000, 0x000000, 0x000000, 0x000000,
  123. 0x000000, 0xffffff, 0x000000, 0x000000, 0x000000, 0x000000,
  124. 0x000000, 0x333333, 0x000000, 0x000000, 0x000000, 0x000000,
  125. 0x000000, 0x777777, 0x777777, 0x777777, 0x777777, 0x000000,
  126. 0x000000, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0x000000,
  127. 0x000000, 0xffffff, 0x000000, 0x000000, 0x000000, 0x000000,
  128. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  129. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  130. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  131. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000 ) );
  132. /** PPM ASCII example (from Wikipedia) */
  133. PNM ( ppm_ascii,
  134. "P3\n"
  135. "# The P3 means colors are in ASCII, then 3 columns and 2 rows,\n"
  136. "# then 255 for max color, then RGB triplets\n"
  137. "3 2\n"
  138. "255\n"
  139. "255 0 0 0 255 0 0 0 255\n"
  140. "255 255 0 255 255 255 0 0 0\n",
  141. 3, 2,
  142. DATA ( 0xff0000, 0x00ff00, 0x0000ff, 0xffff00, 0xffffff, 0x000000 ) );
  143. /** PBM ASCII with no space between pixel values */
  144. PNM ( pbm_ascii_no_space,
  145. "P1\n"
  146. "3 3\n"
  147. "001\n"
  148. "010\n"
  149. "111\n",
  150. 3, 3,
  151. DATA ( 0xffffff, 0xffffff, 0x000000, 0xffffff, 0x000000, 0xffffff,
  152. 0x000000, 0x000000, 0x000000 ) );
  153. /** PBM binary example (converted from Wikipedia) */
  154. PNM ( pbm_binary,
  155. DATA ( 0x50, 0x34, 0x0a, 0x23, 0x20, 0x43, 0x52, 0x45, 0x41, 0x54, 0x4f,
  156. 0x52, 0x3a, 0x20, 0x47, 0x49, 0x4d, 0x50, 0x20, 0x50, 0x4e, 0x4d,
  157. 0x20, 0x46, 0x69, 0x6c, 0x74, 0x65, 0x72, 0x20, 0x56, 0x65, 0x72,
  158. 0x73, 0x69, 0x6f, 0x6e, 0x20, 0x31, 0x2e, 0x31, 0x0a, 0x36, 0x20,
  159. 0x31, 0x30, 0x0a, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08, 0x88, 0x70,
  160. 0x00, 0x00 ),
  161. 6, 10,
  162. DATA ( 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  163. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  164. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  165. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  166. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  167. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  168. 0x000000, 0xffffff, 0xffffff, 0xffffff, 0x000000, 0xffffff,
  169. 0xffffff, 0x000000, 0x000000, 0x000000, 0xffffff, 0xffffff,
  170. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0xffffff,
  171. 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0xffffff ) );
  172. /** PGM binary example (converted from Wikipedia) */
  173. PNM ( pgm_binary,
  174. DATA ( 0x50, 0x35, 0x0a, 0x32, 0x34, 0x20, 0x37, 0x0a, 0x31, 0x35, 0x0a,
  175. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  176. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  177. 0x00, 0x00, 0x00, 0x03, 0x03, 0x03, 0x03, 0x00, 0x00, 0x07, 0x07,
  178. 0x07, 0x07, 0x00, 0x00, 0x0b, 0x0b, 0x0b, 0x0b, 0x00, 0x00, 0x0f,
  179. 0x0f, 0x0f, 0x0f, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00,
  180. 0x07, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0b, 0x00, 0x00, 0x00, 0x00,
  181. 0x00, 0x0f, 0x00, 0x00, 0x0f, 0x00, 0x00, 0x03, 0x03, 0x03, 0x00,
  182. 0x00, 0x00, 0x07, 0x07, 0x07, 0x00, 0x00, 0x00, 0x0b, 0x0b, 0x0b,
  183. 0x00, 0x00, 0x00, 0x0f, 0x0f, 0x0f, 0x0f, 0x00, 0x00, 0x03, 0x00,
  184. 0x00, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0b,
  185. 0x00, 0x00, 0x00, 0x00, 0x00, 0x0f, 0x00, 0x00, 0x00, 0x00, 0x00,
  186. 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x07, 0x07, 0x07, 0x07, 0x00,
  187. 0x00, 0x0b, 0x0b, 0x0b, 0x0b, 0x00, 0x00, 0x0f, 0x00, 0x00, 0x00,
  188. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  189. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  190. 0x00, 0x00, 0x00 ),
  191. 24, 7,
  192. DATA ( 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  193. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  194. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  195. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  196. 0x000000, 0x333333, 0x333333, 0x333333, 0x333333, 0x000000,
  197. 0x000000, 0x777777, 0x777777, 0x777777, 0x777777, 0x000000,
  198. 0x000000, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0x000000,
  199. 0x000000, 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000,
  200. 0x000000, 0x333333, 0x000000, 0x000000, 0x000000, 0x000000,
  201. 0x000000, 0x777777, 0x000000, 0x000000, 0x000000, 0x000000,
  202. 0x000000, 0xbbbbbb, 0x000000, 0x000000, 0x000000, 0x000000,
  203. 0x000000, 0xffffff, 0x000000, 0x000000, 0xffffff, 0x000000,
  204. 0x000000, 0x333333, 0x333333, 0x333333, 0x000000, 0x000000,
  205. 0x000000, 0x777777, 0x777777, 0x777777, 0x000000, 0x000000,
  206. 0x000000, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0x000000, 0x000000,
  207. 0x000000, 0xffffff, 0xffffff, 0xffffff, 0xffffff, 0x000000,
  208. 0x000000, 0x333333, 0x000000, 0x000000, 0x000000, 0x000000,
  209. 0x000000, 0x777777, 0x000000, 0x000000, 0x000000, 0x000000,
  210. 0x000000, 0xbbbbbb, 0x000000, 0x000000, 0x000000, 0x000000,
  211. 0x000000, 0xffffff, 0x000000, 0x000000, 0x000000, 0x000000,
  212. 0x000000, 0x333333, 0x000000, 0x000000, 0x000000, 0x000000,
  213. 0x000000, 0x777777, 0x777777, 0x777777, 0x777777, 0x000000,
  214. 0x000000, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0xbbbbbb, 0x000000,
  215. 0x000000, 0xffffff, 0x000000, 0x000000, 0x000000, 0x000000,
  216. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  217. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  218. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000,
  219. 0x000000, 0x000000, 0x000000, 0x000000, 0x000000, 0x000000 ) );
  220. /** PPM binary example (converted from Wikipedia) */
  221. PNM ( ppm_binary,
  222. DATA ( 0x50, 0x36, 0x0a, 0x33, 0x20, 0x32, 0x0a, 0x32, 0x35, 0x35, 0x0a,
  223. 0xff, 0x00, 0x00, 0x00, 0xff, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff,
  224. 0x00, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 ),
  225. 3, 2,
  226. DATA ( 0xff0000, 0x00ff00, 0x0000ff, 0xffff00, 0xffffff, 0x000000 ) );
  227. /**
  228. * Report PNM test result
  229. *
  230. * @v test PNM test
  231. */
  232. #define pnm_ok( test ) do { \
  233. struct pixel_buffer *pixbuf; \
  234. uint8_t data[ (test)->len ]; \
  235. int rc; \
  236. \
  237. /* Sanity check */ \
  238. assert ( ( (test)->width * (test)->height * \
  239. sizeof ( (test)->data[0] ) ) == (test)->len ); \
  240. \
  241. /* Correct image data pointer */ \
  242. (test)->image->data = \
  243. virt_to_user ( ( void * ) (test)->image->data ); \
  244. \
  245. /* Perform tests */ \
  246. ok ( image_probe ( (test)->image ) == 0 ); \
  247. ok ( (test)->image->type == &pnm_image_type ); \
  248. ok ( ( rc = image_pixbuf ( (test)->image, &pixbuf ) ) == 0 ); \
  249. if ( rc == 0 ) { \
  250. ok ( pixbuf->width == (test)->width ); \
  251. ok ( pixbuf->height == (test)->height ); \
  252. ok ( pixbuf->len == (test)->len ); \
  253. copy_from_user ( data, pixbuf->data, 0, \
  254. sizeof ( data ) ); \
  255. ok ( memcmp ( data, (test)->data, \
  256. sizeof ( data ) ) == 0 ); \
  257. DBGC_HDA ( (test)->image, 0, data, sizeof ( data ) ); \
  258. pixbuf_put ( pixbuf ); \
  259. } \
  260. } while ( 0 )
  261. /**
  262. * Perform PNM self-test
  263. *
  264. */
  265. static void pnm_test_exec ( void ) {
  266. pnm_ok ( &pbm_ascii );
  267. pnm_ok ( &pgm_ascii );
  268. pnm_ok ( &ppm_ascii );
  269. pnm_ok ( &pbm_ascii_no_space );
  270. pnm_ok ( &pbm_binary );
  271. pnm_ok ( &pgm_binary );
  272. pnm_ok ( &ppm_binary );
  273. }
  274. /** PNM self-test */
  275. struct self_test pnm_test __self_test = {
  276. .name = "pnm",
  277. .exec = pnm_test_exec,
  278. };