SSL_MarchBRamTest2.c 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. /**********************************************************************
  2. * © 2010 Microchip Technology Inc.
  3. *
  4. * FileName: SSL_MarchBRamTest.c
  5. * Dependencies: Header (.h) files if applicable, see below
  6. * Processor: PIC16FXXX
  7. * Compiler: c18 v3.41
  8. *
  9. * SOFTWARE LICENSE AGREEMENT:
  10. * Microchip Technology Inc. (“Microchip”) licenses this software to you
  11. * solely for use with Microchip PIC® microcontroller
  12. * products. The software is owned by Microchip and is protected under
  13. * applicable copyright laws. All rights reserved.
  14. *
  15. * SOFTWARE IS PROVIDED “AS IS.” MICROCHIP EXPRESSLY DISCLAIMS ANY
  16. * WARRANTY OF ANY KIND, WHETHER EXPRESS OR IMPLIED, INCLUDING BUT NOT
  17. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
  18. * PARTICULAR PURPOSE, OR NON-INFRINGEMENT. IN NO EVENT SHALL MICROCHIP
  19. * BE LIABLE FOR ANY INCIDENTAL, SPECIAL, INDIRECT OR CONSEQUENTIAL
  20. * DAMAGES, LOST PROFITS OR LOST DATA, HARM TO YOUR EQUIPMENT, COST OF
  21. * PROCUREMENT OF SUBSTITUTE GOODS, TECHNOLOGY OR SERVICES, ANY CLAIMS
  22. * BY THIRD PARTIES (INCLUDING BUT NOT LIMITED TO ANY DEFENSE THEREOF),
  23. * ANY CLAIMS FOR INDEMNITY OR CONTRIBUTION, OR OTHER SIMILAR COSTS.
  24. *
  25. * REVISION HISTORY:
  26. *~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  27. * Author Date Comments on this revision
  28. *~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  29. * CT 08/15/2008 First release of source file
  30. * Mike Cahill 11/11/2010 Updated for HI-TECH v9.80
  31. * MVL 02/22/2011 Modified for HI-TECH v9.80 & v9.81
  32. *
  33. *~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  34. * ADDITIONAL NOTES:
  35. *
  36. **********************************************************************/
  37. #include "SSL_MarchBRamTest2.h"
  38. #define MAX_MEM ( MARCHB_RAM_STOP_ADDRESS - MARCHB_RAM_START_ADDRESS +1 )
  39. volatile unsigned char *data = MARCHB_RAM_START_ADDRESS;
  40. volatile unsigned int i;
  41. void main()
  42. {
  43. volatile unsigned char testResult;
  44. testResult = SSL_RAMtest_MarchB();
  45. if (testResult == MARCHB_RAM_TEST_PASS)
  46. {
  47. Nop(); /* Test pass */
  48. }
  49. else
  50. {
  51. Nop(); /* Test not pass */
  52. }
  53. }
  54. /*******************************************************************
  55. * Description : This function implements the March B test. It is a complete and irredundant test
  56. * capable of detecting stuck-at faults , linked coupling Idempotent faults or Inversion Coupling
  57. * faults. This test is of complexity 17n( Where n is the number of bits).
  58. * Input:
  59. * *data : pointer to an array declared in user memory
  60. * MAX_MEM : value indicating the number of bytes to test
  61. * Return Values:
  62. * MARCHB_RAM_TEST_FAIL : return value = 0
  63. * MARCHB_RAM_TEST_PASS : return value = 1
  64. *
  65. *******************************************************************/
  66. unsigned char SSL_RAMtest_MarchB( void )
  67. {
  68. volatile unsigned char testResult;
  69. //***********************************************
  70. for ( i=0;i<=(MAX_MEM-1);i++)
  71. {
  72. data[i]=0x00;
  73. }
  74. //***********************************************
  75. for ( i=0;i<=(MAX_MEM-1);i++)
  76. {
  77. testResult = Rd0Wr1Rd1Wr0Rd0Wr1( );
  78. if ( !testResult)
  79. return MARCHB_RAM_TEST_FAIL;
  80. }
  81. //***********************************************
  82. for ( i=0;i<=(MAX_MEM-1);i++)
  83. {
  84. testResult = Rd1Wr0Wr1( );
  85. if ( !testResult)
  86. return MARCHB_RAM_TEST_FAIL;
  87. }
  88. //***********************************************
  89. for (i=(MAX_MEM-1); i > 0;i--)
  90. {
  91. testResult = Rd1Wr0Wr1Wr0( );
  92. if ( !testResult)
  93. return MARCHB_RAM_TEST_FAIL;
  94. }
  95. // do this once more time for zero
  96. testResult = Rd1Wr0Wr1Wr0 ( );
  97. if ( !testResult)
  98. return MARCHB_RAM_TEST_FAIL;
  99. //***********************************************
  100. for (i=(MAX_MEM-1); i > 0;i--)
  101. {
  102. testResult = Rd0Wr1Wr0( );
  103. if ( !testResult)
  104. return MARCHB_RAM_TEST_FAIL;
  105. }
  106. // do this once more time for zero
  107. testResult = Rd0Wr1Wr0( );
  108. if ( !testResult)
  109. return MARCHB_RAM_TEST_FAIL;
  110. //***********************************************
  111. return MARCHB_RAM_TEST_PASS;
  112. }
  113. //***********************************************
  114. unsigned char Rd0Wr1Rd1Wr0Rd0Wr1( void )
  115. {
  116. volatile unsigned char r;
  117. // read zero , write 1
  118. for (r=0; r<8;r++)
  119. {
  120. if ( (data[i] >>r ) & 0x01)
  121. return FAIL;
  122. else
  123. data[i]=data[i] | (1<<r);
  124. }
  125. // read one write zero
  126. for (r=0; r<8;r++)
  127. {
  128. if ( ((data[i] >>r ) & 0x01) != 0x01)
  129. return FAIL;
  130. else
  131. data[i]=data[i] & ~(1<<r);
  132. }
  133. // read zero , write 1
  134. for (r=0; r<8;r++)
  135. {
  136. if ( (data[i] >>r ) & 0x01)
  137. return FAIL;
  138. else
  139. data[i]=data[i] | (1<<r);
  140. }
  141. return PASS;
  142. }
  143. //***********************************************
  144. unsigned char Rd1Wr0Wr1( void )
  145. {
  146. volatile unsigned char r;
  147. // read one write zero write one
  148. for (r=0; r<8;r++)
  149. {
  150. if ( ((data[i] >>r ) & 0x01) != 0x01)
  151. return FAIL;
  152. else
  153. {
  154. data[i]=data[i] & ~(1<<r);
  155. data[i]=data[i] | (1<<r);
  156. }
  157. }
  158. return PASS;
  159. }
  160. //***********************************************
  161. unsigned char Rd1Wr0Wr1Wr0( void )
  162. {
  163. volatile unsigned char r;
  164. // read one write zero write one, write 1 , write 0
  165. for (r=0; r<8;r++)
  166. {
  167. if ( ((data[i] >>r ) & 0x01) != 0x01)
  168. return FAIL;
  169. else
  170. {
  171. data[i]=data[i] & ~(1<<r);
  172. data[i]=data[i] | (1<<r);
  173. data[i]=data[i] & ~(1<<r);
  174. }
  175. }
  176. return PASS;
  177. }
  178. unsigned char Rd0Wr1Wr0( void )
  179. {
  180. volatile unsigned char r;
  181. // read zero , write 1, write 0
  182. for (r=0; r<8;r++)
  183. {
  184. if ( (data[i] >>r ) & 0x01)
  185. return FAIL;
  186. else
  187. {
  188. data[i]=data[i] | (1<<r);
  189. data[i]=data[i] & ~(1<<r);
  190. }
  191. }
  192. return PASS;
  193. }