/************************************************************************* * HB QUICK TEST * * Tests one Hit Buffer board. * * It performs VME standalone tests first, then data tests * * using two or three other boards: Hit Senderer and Road Senderer. * * One board is also needed as Receiver. * * Sender and Receiver Boards can be Mergers or HB or AMS. * * Receiver can be same board as one of the Sender, or separate. * * * * Compile this program with: svtvmecomp hb_quick_test * * also need first to copy hb_address.h from $SVTVME_DIR/src to * * current directory. This may change as SVTVME pacakge evolves * * * **************************************************************************/ /* *** REVISION HISTORY * 25 May 00: S.Belforte. Original creation from hbqt.c and hbft.c * Still very limited. Sender and Receiver baords * can only be HitBuffers and crate/slot is * hardwired in the code. * No full data test yet, only 4 words. * No Spy Buffer test * Still uses a lot of old vmesvt calls in * addition to new svtvme stuff. * **************************************************************************/ #include "svt_functions.h" #include "hb_functions.h" #include "hb_address.h" #include "VISION.h" svtvme_t *HitSender, *RoadSender, *Receiver; uint4 rand16(); void bit_print(int v, int pos); void reset_hb_PowerOnState(svtvme_t *board); int check_hb_PowerOnState(svtvme_t *board); int test_register(uint4 address, uint4 mask, svtvme_t *board); int test_ram(uint4 address, uint4 size, uint4 mask, int repeat, svtvme_t *board); int largeVISIONwrite (VISION_SLAVE slave, unsigned int offset, unsigned int req_bytes, unsigned int *real_bytes, void *data ); int largeVISIONread (VISION_SLAVE slave, unsigned int offset, unsigned int req_bytes, unsigned int *real_bytes, void *data ); void define_configuration(); void prepare_HitSender(svtvme_t *board); void prepare_RoadSender(svtvme_t *board); void prepare_Receiver(svtvme_t *board); void sendData(uint4 nw, uint4 *Data, svtvme_t *board); void getData(uint4 nw, int *readw, uint4 *Data, svtvme_t *board); int main(int argc, char * argv[]) { char verb[10]; unsigned long error_flag, error_enable; unsigned long tmode, hit_spy, roadlimit, phisector; unsigned long fifo = 0x678; unsigned long hold, idprom; unsigned long data, mdata; int status, i; int hb1add; char crate[20]; svtvme_t *hb1; uint4 *Hits; uint4 *Roads; uint4 *Outs; uint4 *Data; uint4 dummy; uint4 nhits, nroads, nouts, nw; int readw; char HitSenderCrate[40]; char RoadSenderCrate[40]; char ReceiverCrate[40]; int HitSenderSlot; int RoadSenderSlot; int ReceiverSlot; if (argc != 3) { printf("Usage: %s \n",argv[0]); exit (1); } sscanf(argv[1], "%s", crate); sscanf(argv[2], "%d", &hb1add); printf("Will QuickTest HitBuffer in slot %d of crate %s\n", hb1add,crate); strcpy(verb,"zzz"); hb1 = svtvme_svt_open(crate, hb1add); hb1->fpdebug=0; reset_hb_PowerOnState(hb1); assert (check_hb_PowerOnState(hb1)); /* * Test Enable */ status = svtvme_hb_tModeEnable(hb1); printf(" Test Mode enabled with status %d\n", status); status = svtvme_hb_tModeStatus(&tmode, hb1); printf(" Test Mode state : "); bit_print(tmode,1); assert ( (tmode&1)==1 ); printf(" did TM enable work ? Is run LED off ?\n");scanf("%s",verb); /* * Test R/W Registers */ printf("testing HB_OUTPUT register ... "); assert (test_register (HB_OUTPUT_REG, HB_OUTPUT_MASK, hb1)); printf("OK\n"); printf("testing FREEZE_VME register ... "); assert (test_register (HB_FREZZE_REG, HB_FREEZE_MASK, hb1)); printf("OK\n"); printf("testing ERROR_LINE_ENABLE register ... "); assert (test_register (HB_ERREN_REG, HB_ERREN_MASK, hb1)); printf("OK\n"); printf("testing CDF_ERROR_ENABLE register ... "); assert (test_register (HB_CDF_EN_REG, HB_CDF_ERR_MASK, hb1)); printf("OK\n"); /* * Test RAM */ printf("testing ID PROM ... \n"); assert (test_prom (hb1)); printf("ID PROM OK\n\n"); printf("testing SS_MAP memory ... "); fflush(0); assert (test_ram (HB_SS_MAP_REG, HB_SS_MAP_LENGTH, HB_SS_MAP_MASK, 1, hb1)); printf("OK\n"); printf("testing AM_MAP memory ... "); fflush(0); assert (test_ram (HB_AM_MAP_REG, HB_AM_MAP_LENGTH, HB_AM_MAP_MASK, 1, hb1)); printf("OK\n"); /* * Init */ status = svtvme_hb_init(hb1); printf("\n Init done with status %d\n\n", status); status = svtvme_hb_tModeStatus(&tmode, hb1); printf(" Test Mode state : "); bit_print(tmode,1); assert ( (tmode&1)==0 ); printf(" did Init work ? Is run LED on (GREEN) ?\n");scanf("%s",verb); /* * DATA PROCESSING */ status = svtvme_hb_tModeEnable(hb1); printf(" Test Mode enabled with status %d\n", status); status = svtvme_hb_tModeStatus(&tmode, hb1); assert ( (tmode&1)==1 ); data = 0; status = svtvme_hb_setState(HB_CDF_ERR_EN, data, hb1); status = svtvme_hb_setState(HB_ERREN, data, hb1); define_configuration(); prepare_HitSender(HitSender); prepare_RoadSender(RoadSender); /* prepare some generic words to test data paths */ nw=4; assert (Data=malloc(nw*4)); assert (Hits=malloc(nw*4)); assert (Roads=malloc(nw*4)); assert (Outs=malloc(nw*4)); Data[0] = 0x255555; Data[1] = 0x2aaaaa; Data[2] = 0x255555; Data[3] = 0x2aaaaa; for (i=0; i 3969) */ /* all done, now must run extensive ram/ss tests and random test */ reset_hb_PowerOnState(hb1); svtvme_svt_close(hb1); } /*==================================================================*/ /*==================== END OF MAIN ===============================*/ /*==================================================================*/ /*------------------------------------------------------------------*/ void reset_hb_PowerOnState(svtvme_t *board) { int status; uint4 data; data = 0xFF; status = svtvme_hb_setState(HB_ERREN, data, board); data = 0; status = svtvme_hb_setState(HB_CDF_ERR_EN, data, board); status = svtvme_hb_init(board); } /*------------------------------------------------------------------*/ int check_hb_PowerOnState(svtvme_t *board){ int status; uint4 data, mdata; /* * Dump and check HB PowerOn state */ status = svtvme_hb_tModeStatus(&data, board); mdata = data & HB_TMOD_MASK; printf(" Test Mode state : "); bit_print(data,1); assert( mdata==0 ); status = svtvme_hb_getState(HB_ERROR, &data, board); mdata = data & HB_ERROR_MASK; printf("ERROR REGISTER = %02x ",mdata); bit_print(mdata, 8); assert( mdata==0 ); status = svtvme_hb_getState(HB_HIT_FIFO, &data, board); mdata = data & HB_HIT_F_S_MASK; printf("HIT FIFO STATUS = %2x ",mdata); bit_print(mdata, 3); assert( mdata==6 ); status = svtvme_hb_getState(HB_ROAD_FIFO, &data, board); mdata = data & HB_ROAD_F_S_MASK; printf("ROAD FIFO STATUS = %2x ",mdata); bit_print(mdata, 3); assert( mdata==6 ); status = svtvme_hb_getState(HB_HOLD, &data, board); mdata = data & HB_HOLD_MASK; printf("OUTPUT HOLD STATUS = %2x ",mdata); bit_print(mdata, 1); status = svtvme_hb_getState(HB_FSM, &data, board); mdata = data & HB_FSM_MASK; printf("FSM STATUS = %2x ",mdata); bit_print(mdata, 4); assert( mdata==0 ); status = svtvme_hb_getState(HB_FSMH, &data, board); mdata = data & HB_FSMH_MASK; printf("FSMH STATUS = %2x ",mdata); bit_print(mdata, 2); assert( mdata==3 ); status = svtvme_hb_getState(HB_FSMR, &data, board); mdata = data & HB_FSMR_MASK; printf("FSMR STATUS = %2x ",mdata); bit_print(mdata, 2); assert( mdata==0 ); status = svtvme_hb_getState(HB_OUTPUT, &data, board); mdata = data & HB_OUTPUT_MASK; printf("OUTPUT REGISTER= %06x ",mdata); bit_print(mdata, 23); assert( mdata==0 ); status = svtvme_hb_getState(HB_FREEZE, &data, board); mdata = data & HB_FREEZE_MASK; printf("FREEZE VME = %2x ",mdata); bit_print(mdata, 1); assert( mdata==0 ); assert ( test_spy_reg(HB_HIT_SPY, board) ); assert ( test_spy_reg(HB_ROAD_SPY, board) ); assert ( test_spy_reg(HB_OUT_SPY, board) ); status = svtvme_hb_getState(HB_ERREN, &data, board); mdata = data & HB_ERREN_MASK; printf("SVT ERROR ENABLE = %02x ",mdata); bit_print(mdata, 8); assert( mdata==0xFF ); status = svtvme_hb_getState(HB_CDF_ERR_EN, &data, board); mdata = data & HB_CDF_ERR_MASK; printf("CDF ERROR ENABLE = %2x ",mdata); bit_print(mdata, 1); assert( mdata==0 ); status = svtvme_hb_getState(HB_CDF_ERR_ST, &data, board); mdata = data & HB_CDF_ERR_MASK; printf("CDF ERROR STATUS = %2x ",mdata); bit_print(mdata, 1); assert( mdata==1 ); status = svtvme_hb_getState(HB_DIP_STAT, &data, board); mdata = data & HB_DIP_MASK; printf("DIP SWITCHES = %2x ",mdata); bit_print(mdata, 4); assert( mdata==15 ); } /*------------------------------------------------------------------*/ int test_spy_reg(uint4 spyreg, svtvme_t *board){ int status; char reg[4]; uint4 data,mdata; if (spyreg == HB_HIT_SPY) strcpy(reg,"HIT"); else if (spyreg == HB_ROAD_SPY) strcpy(reg,"ROAD"); else if (spyreg == HB_OUT_SPY) strcpy(reg,"OUT"); else { printf("test_hb_spy- wrong 1st argument: %d\n",spyreg); return 0; } status = svtvme_hb_getState(spyreg, &data, board); mdata = data & SPY_POINTER; printf("%s SPY POINTER = %05x ",reg, mdata); bit_print(mdata, 17); if (mdata != 0) { printf (" Try to reset it: "); status = svtvme_hb_resetState(spyreg, board); status = svtvme_hb_getState(spyreg, &data, board); mdata = data & SPY_POINTER; printf("%s SPY POINTER = %05x ",reg, mdata); bit_print(mdata, 17); } assert( mdata==0 || mdata==1 ); mdata = (data & SPY_WRAP)>>17; printf("%s SPY WRAP = %2x ",reg, mdata); bit_print(mdata, 1); assert( mdata==0 ); mdata = (data & SPY_FREEZE)>>18; printf("%s SPY FREEZE = %2x ",reg, mdata); bit_print(mdata, 1); assert( mdata==1 ); return 1; } /*------------------------------------------------------------------*/ int test_register(uint4 address, uint4 mask, svtvme_t *board) { uint4 wdata; uint4 rdata; unsigned int nXfer; int i,j,nbits; int status; int ok=1; /* find the register length */ j=0; for (i=0; i<32; i++) { j |= 1<vs, add, sizeof(wdata), &nXfer, &wdata); status= VISIONread (board->vs, add, sizeof(wdata), &nXfer, &rdata); rdata &= mask; if (rdata != wdata) ok = 0; return ok; } /*------------------------------------------------------------------*/ int test_ram(uint4 address, uint4 size, uint4 mask, int repeat, svtvme_t *board) { uint4 *tdata; unsigned int XfBytes; int i, n; int status; int ok=1; uint4 offset; uint4 nbytes; const int wordsInBunch = 128*1024; const int bytesInBunch = sizeof(uint4) * wordsInBunch; nbytes = size * sizeof(uint4); tdata = malloc (nbytes); assert (tdata); /* fill with 0 */ /* printf("0."); fflush(0); for (i=0; ivs, add, nbytes, &nXfer, data); status= largeVISIONread (board->vs, add, nbytes, &nXfer, rdata); for (i=0; i0); if (status <= 0) printf("VME error. ID Prom read with status %d\n\n", status); else for (i=0; i>24 & 0xFF; FoundTerm = 0; PreTerm=0; j = 0; refprom = 0; repeat0 = 1; error=0; for (i=0; i 32) i = 32; for (i=1;i <= (32-pos); ++i) { v <<= 1; } for (i=1;i <= pos; ++i) { putchar(((v & mask) == 0) ? '0' : '1'); v <<=1; if ((32 - pos + i) % 8 ==0 && i != 32) putchar(' '); } printf("\n"); } /*==================================================================*/ /*==================== DATA SEND/READ STUFF =======================*/ /*==================================================================*/ void define_configuration() { char HitSenderCrate[40]; char RoadSenderCrate[40]; char ReceiverCrate[40]; int HitSenderSlot; int RoadSenderSlot; int ReceiverSlot; strcpy (HitSenderCrate,"vmesvt1.ts.infn.it"); HitSenderSlot=5; strcpy (RoadSenderCrate,"vmesvt1.ts.infn.it"); RoadSenderSlot=6; strcpy (ReceiverCrate,"vmesvt1.ts.infn.it"); ReceiverSlot=5; HitSender = svtvme_svt_open(HitSenderCrate, HitSenderSlot); HitSender->fpdebug=0; RoadSender = svtvme_svt_open(RoadSenderCrate, RoadSenderSlot); RoadSender->fpdebug=0; Receiver = svtvme_svt_open(ReceiverCrate, ReceiverSlot); Receiver->fpdebug=0; } /*------------------------------------------------------------------*/ void prepare_HitSender(svtvme_t *board) { int status; status = svtvme_hb_init(board); status = svtvme_hb_tModeEnable(board); } /*------------------------------------------------------------------*/ void prepare_RoadSender(svtvme_t *board) { int status; status = svtvme_hb_init(board); status = svtvme_hb_tModeEnable(board); } /*------------------------------------------------------------------*/ void prepare_Receiver(svtvme_t *board) { int status; status = svtvme_hb_init(board); status = svtvme_hb_tModeEnable(board); } /*------------------------------------------------------------------*/ void sendData(uint4 nw, uint4 *Data, svtvme_t *board) { int status; int nXfer; int i; for (i=0; ivs, HB_OUTPUT_REG, 4, &nXfer, Data+i); } } /*------------------------------------------------------------------*/ int SenderHold(svtvme_t *board) { int status; uint4 data; status = svtvme_hb_getState (HB_HOLD, &data, board); if (data==0) return 1; /* hold is true */ else return 0; /* hold is false */ } /*------------------------------------------------------------------*/ void getData(uint4 nw, int *readw, uint4 *Data, svtvme_t *board) { int status; uint4 moreData; *readw = svtvme_svt_readFifo (HB_HIT_FIFO, nw, &moreData, Data, board); return; } /*------------------------------------------------------------------*/ /*------------------------------------------------------------------*/