config.c
来自「ddr and sdram memory check,ddr and sdram」· C语言 代码 · 共 594 行
C
594 行
/* config.c - MemTest-86 Version 3.0 * * Released under version 2 of the Gnu Public License. * By Chris Brady, cbrady@sgi.com * ---------------------------------------------------- * MemTest86+ V1.30 Specific code (GPL V2.0) * By Samuel DEMEULEMEESTER, sdemeule@memtest.org * http://www.x86-secret.com - http://www.memtest.org */#include "test.h"#include "screen_buffer.h"#include "controller.h"#include "extra.h"#define ITER 20extern int bail, beepmode;extern struct tseq tseq[];/* extern struct vars *v; */extern short e820_nr;extern char memsz_mode;int fast_mode;char save[POP_H][POP_W];void get_config(){ int flag = 0, sflag = 0, i, prt = 0; int reprint_screen = 0; ulong page; popup(); wait_keyup(); while(!flag) { cprint(POP_Y+1, POP_X+2, "Configuration:"); cprint(POP_Y+3, POP_X+6, "(1) Cache Mode"); cprint(POP_Y+4, POP_X+6, "(2) Test Selection"); cprint(POP_Y+5, POP_X+6, "(3) Address Range"); cprint(POP_Y+6, POP_X+6, "(4) Memory Sizing"); cprint(POP_Y+7, POP_X+6, "(5) Error Summary"); cprint(POP_Y+8, POP_X+6, "(6) Error Report Mode"); cprint(POP_Y+9, POP_X+6, "(7) ECC Mode"); cprint(POP_Y+10, POP_X+6, "(8) Restart Test"); cprint(POP_Y+11, POP_X+6, "(9) Adv. Options"); cprint(POP_Y+12, POP_X+6, "(0) Exit"); /* Wait for key release */ /* Fooey! This nuts'es up the serial input. */ sflag = 0; switch(get_key()) { case 2: /* 1 - Set cache mode */ popclear(); cprint(POP_Y+1, POP_X+2, "Cache Mode:"); cprint(POP_Y+3, POP_X+6, "(1) Test Controlled"); cprint(POP_Y+4, POP_X+6, "(2) Always On"); cprint(POP_Y+5, POP_X+6, "(3) Always Off"); cprint(POP_Y+6, POP_X+6, "(0) Cancel"); cprint(POP_Y+3+v->cache_flag, POP_X+5, ">"); wait_keyup(); while (!sflag) { switch(get_key()) { case 2: /* test controled */ v->cache_flag = 0; set_cache(tseq[v->test].cache); find_ticks(); sflag++; break; case 3: /* Cache on */ v->cache_flag = 1; if (tseq[v->test].cache == 0) { bail++; } set_cache(1); find_ticks(); sflag++; break; case 4: /* Cache off */ v->cache_flag = 2; if (tseq[v->test].cache == 1) { bail++; } find_ticks(); sflag++; break; case 11: case 57: sflag++; break; } } popclear(); break; case 3: /* 2 - Test Selection */ popclear(); cprint(POP_Y+1, POP_X+2, "Test Selection:"); cprint(POP_Y+3, POP_X+6, "(1) Default Tests"); cprint(POP_Y+4, POP_X+6, "(2) Quick Tests"); cprint(POP_Y+5, POP_X+6, "(3) Extended Tests"); cprint(POP_Y+6, POP_X+6, "(4) All Tests"); cprint(POP_Y+7, POP_X+6, "(5) Skip Current Test"); cprint(POP_Y+8, POP_X+6, "(6) Select Test"); cprint(POP_Y+9, POP_X+6, "(7) Print mode"); cprint(POP_Y+10, POP_X+6, "(0) Cancel"); if (v->testsel < 0) { if (fast_mode == 1) { cprint(POP_Y+4, POP_X+5, ">"); } else { if (v->xtst_flag == 0) { cprint(POP_Y+3, POP_X+5, ">"); } else { cprint(POP_Y+4+v->xtst_flag, POP_X+5, ">"); } } } else { cprint(POP_Y+8, POP_X+5, ">"); } wait_keyup(); while (!sflag) { switch(get_key()) { case 2: /* Default */ v->xtst_flag = 0; fast_mode = 0; if (v->test > DEFTESTS) { bail++; } v->testsel = -1; find_ticks(); sflag++; cprint(LINE_INFO, COL_TST, " Std"); break; case 3: /* Fast */ v->xtst_flag = 0; fast_mode = 1; if (v->test > DEFTESTS) { bail++; } v->testsel = -1; v->pass = 0; v->ecount = 0; find_ticks(); sflag++; cprint(LINE_INFO, COL_TST, "Fast"); break; case 4: /* Extended */ v->xtst_flag = 1; fast_mode = 0; if (v->test <= DEFTESTS) { bail++; } v->testsel = -1; find_ticks(); sflag++; cprint(LINE_INFO, COL_TST, " Ext"); break; case 5: /* All */ fast_mode = 0; v->xtst_flag = 2; v->testsel = -1; find_ticks(); sflag++; cprint(LINE_INFO, COL_TST, " All"); break; case 6: /* Skip test */ bail++; sflag++; break; case 7: /* Select test */ popclear(); cprint(POP_Y+1, POP_X+2, "Test Selection:"); cprint(POP_Y+3, POP_X+4, "Test Number [0-12]: "); i = getval(POP_Y+3, POP_X+24, 0); if (i <= 12) { if (i != v->testsel) { v->pass = 0; v->ecount = 0; } v->testsel = i; } v->test = -1; v->pass = -1; find_ticks(); sflag++; bail++; cprint(LINE_INFO, COL_TST, " #"); dprint(LINE_INFO, COL_TST+1, i, 2, 1); break; case 11: case 57: sflag++; break; } } popclear(); break; case 4: /* 3 - Address Range */ popclear(); cprint(POP_Y+1, POP_X+2, "Test Address Range:"); cprint(POP_Y+3, POP_X+6, "(1) Set Lower Limit"); cprint(POP_Y+4, POP_X+6, "(2) Set Upper Limit"); cprint(POP_Y+5, POP_X+6, "(3) Test All Memory"); cprint(POP_Y+6, POP_X+6, "(0) Cancel"); wait_keyup(); while (!sflag) { switch(get_key()) { case 2: /* Lower Limit */ popclear(); cprint(POP_Y+2, POP_X+4, "Lower Limit: "); cprint(POP_Y+4, POP_X+4, "Current: "); aprint(POP_Y+4, POP_X+13, v->plim_lower); cprint(POP_Y+6, POP_X+4, "New: "); page = getval(POP_Y+6, POP_X+9, 12); if (page + 1 <= v->plim_upper) { v->plim_lower = page; bail++; } adj_mem(); find_ticks(); sflag++; break; case 3: /* Upper Limit */ popclear(); cprint(POP_Y+2, POP_X+4, "Upper Limit: "); cprint(POP_Y+4, POP_X+4, "Current: "); aprint(POP_Y+4, POP_X+13, v->plim_upper); cprint(POP_Y+6, POP_X+4, "New: "); page = getval(POP_Y+6, POP_X+9, 12); if (page - 1 >= v->plim_lower) { v->plim_upper = page; bail++; } adj_mem(); find_ticks(); sflag++; break; case 4: /* All of memory */ v->plim_lower = 0; v->plim_upper = v->pmap[v->msegs - 1].end; bail++; adj_mem(); find_ticks(); sflag++; break; case 11: case 57: /* 0/CR - Cancel */ sflag++; break; } } popclear(); break; case 5: /* 4 - Memory Sizing */ popclear(); cprint(POP_Y+1, POP_X+2, "Memory Sizing:"); cprint(POP_Y+3, POP_X+6, "(1) BIOS - Std"); if (e820_nr) { cprint(POP_Y+4, POP_X+6, "(2) BIOS - All"); cprint(POP_Y+5, POP_X+6, "(3) Probe"); cprint(POP_Y+6, POP_X+6, "(0) Cancel"); cprint(POP_Y+2+memsz_mode, POP_X+5, ">"); } else { cprint(POP_Y+4, POP_X+6, "(3) Probe"); cprint(POP_Y+5, POP_X+6, "(0) Cancel"); if (memsz_mode == SZ_MODE_BIOS) { cprint(POP_Y+3, POP_X+5, ">"); } else { cprint(POP_Y+4, POP_X+5, ">"); } } wait_keyup(); while (!sflag) { switch(get_key()) { case 2: memsz_mode = SZ_MODE_BIOS; wait_keyup(); restart();/* mem_size(); v->test = 0; v->pass = 0; v->total_ticks = 0; bail++; sflag++;*/ break; case 3: memsz_mode = SZ_MODE_BIOS_RES; wait_keyup(); restart();/* mem_size(); v->test = 0; v->pass = 0; v->total_ticks = 0; bail++; sflag++;*/ break; case 4: memsz_mode = SZ_MODE_PROBE; wait_keyup(); restart();/* mem_size(); v->test = 0; v->pass = 0; v->total_ticks = 0; bail++; sflag++;*/ break; case 11: case 57: /* 0/CR - Cancel */ sflag++; break; } } popclear(); break; case 6: /* 5 - Show error summary */ popclear(); for (i=0; tseq[i].msg != NULL; i++) { cprint(POP_Y+1+i, POP_X+2, "Test:"); dprint(POP_Y+1+i, POP_X+8, i, 2, 1); cprint(POP_Y+1+i, POP_X+12, "Errors:"); dprint(POP_Y+1+i, POP_X+20, tseq[i].errors, 5, 1); } wait_keyup(); while (get_key() == 0); popclear(); break; case 7: /* 6 - Printing Mode */ popclear(); cprint(POP_Y+1, POP_X+2, "Printing Mode:"); cprint(POP_Y+3, POP_X+6, "(1) Individual Errors"); cprint(POP_Y+4, POP_X+6, "(2) BadRAM Patterns"); cprint(POP_Y+5, POP_X+6, "(3) Error Counts Only"); cprint(POP_Y+6, POP_X+6, "(4) Beep on Error"); cprint(POP_Y+7, POP_X+6, "(0) Cancel"); cprint(POP_Y+3+v->printmode, POP_X+5, ">"); if (beepmode) { cprint(POP_Y+6, POP_X+5, ">"); } wait_keyup(); while (!sflag) { switch(get_key()) { case 2: /* Separate Addresses */ v->printmode=PRINTMODE_ADDRESSES; v->eadr = 0; sflag++; break; case 3: /* BadRAM Patterns */ v->printmode=PRINTMODE_PATTERNS; sflag++; prt++; break; case 4: /* Error Counts Only */ v->printmode=PRINTMODE_NONE; sflag++; break; case 5: /* Set Beep On Error mode */ beepmode = !beepmode; sflag++; break; case 11: case 57: /* 0/CR - Cancel */ sflag++; break; } } popclear(); break; case 8: /* 7 - ECC Polling Mode */ popclear(); cprint(POP_Y+1, POP_X+2, "ECC Polling Mode:"); cprint(POP_Y+3, POP_X+6, "(1) Recommended"); cprint(POP_Y+4, POP_X+6, "(2) On"); cprint(POP_Y+5, POP_X+6, "(3) Off"); cprint(POP_Y+6, POP_X+6, "(0) Cancel"); wait_keyup(); while(!sflag) { switch(get_key()) { case 2: set_ecc_polling(-1); sflag++; break; case 3: set_ecc_polling(1); sflag++; break; case 4: set_ecc_polling(0); sflag++; break; case 11: case 57: /* 0/CR - Cancel */ sflag++; break; } } popclear(); break; case 9: wait_keyup(); restart(); break; case 10: // experimental extra options popclear(); cprint(POP_Y+1, POP_X+2, "Adv. Options :"); cprint(POP_Y+3, POP_X+5, "(1) Modify Timing "); cprint(POP_Y+4, POP_X+5, "(2) Reprint Screen"); cprint(POP_Y+5, POP_X+5, "(0) Cancel "); wait_keyup(); while(!sflag) { switch(get_key()) { case 2: popclear(); get_menu(); case 3: reprint_screen = 1; sflag++; flag++; break; //prime(); case 4: break; case 11: case 57: /* 0/CR - Cancel */ sflag++; break; } } popclear(); break; case 11: case 57: case 28: /* 0/CR/SP - Cancel */ flag++; break; } } popdown(); if (prt) { printpatn(); } if (reprint_screen){ tty_print_screen(); }}void popup(){ int i, j; char *pp; for (i=POP_Y; i<POP_Y + POP_H; i++) { for (j=POP_X; j<POP_X + POP_W; j++) { pp = (char *)(SCREEN_ADR + (i * 160) + (j * 2)); save[i-POP_Y][j-POP_X] = get_scrn_buf(i, j); /* Save screen */ set_scrn_buf(i, j, ' '); *pp = ' '; /* Clear */ pp++; *pp = 0x07; /* Change Background to black */ } } tty_print_region(POP_Y, POP_X, POP_Y+POP_H, POP_X+POP_W);}void popdown(){ int i, j; char *pp; for (i=POP_Y; i<POP_Y + POP_H; i++) { for (j=POP_X; j<POP_X + POP_W; j++) { pp = (char *)(SCREEN_ADR + (i * 160) + (j * 2)); *pp = save[i-POP_Y][j-POP_X]; /* Restore screen */ set_scrn_buf(i, j, save[i-POP_Y][j-POP_X]); pp++; *pp = 0x17; /* Reset background color */ } } tty_print_region(POP_Y, POP_X, POP_Y+POP_H, POP_X+POP_W);}void popclear(){ int i, j; char *pp; for (i=POP_Y; i<POP_Y + POP_H; i++) { for (j=POP_X; j<POP_X + POP_W; j++) { pp = (char *)(SCREEN_ADR + (i * 160) + (j * 2)); *pp = ' '; /* Clear screen */ set_scrn_buf(i, j, ' '); pp++; } } tty_print_region(POP_Y, POP_X, POP_Y+POP_H, POP_X+POP_W);}void clear_screen(){ int i; volatile char *pp; for(i=0, pp=(char *)(SCREEN_ADR); i<80*24; i++) { *pp++ = ' '; *pp++ = 0x07; }}void adj_mem(void){ int i; v->selected_pages = 0; for (i=0; i< v->msegs; i++) { /* Segment inside limits ? */ if (v->pmap[i].start >= v->plim_lower && v->pmap[i].end <= v->plim_upper) { v->selected_pages += (v->pmap[i].end - v->pmap[i].start); continue; } /* Segment starts below limit? */ if (v->pmap[i].start < v->plim_lower) { /* Also ends below limit? */ if (v->pmap[i].end < v->plim_lower) { continue; } /* Ends past upper limit? */ if (v->pmap[i].end > v->plim_upper) { v->selected_pages += v->plim_upper - v->plim_lower; } else { /* Straddles lower limit */ v->selected_pages += (v->pmap[i].end - v->plim_lower); } continue; } /* Segment ends above limit? */ if (v->pmap[i].end > v->plim_upper) { /* Also starts above limit? */ if (v->pmap[i].start > v->plim_upper) { continue; } /* Straddles upper limit */ v->selected_pages += (v->plim_upper - v->pmap[i].start); } }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?