assign cr_nWE = decode ? ~wrlatch : 1;
assign cr_DQ = (~cr_nOE) ? 16'bzzzzzzzzzzzzzzzz : {8'b0, datalatch};
- assign cr_A = (addrlatch[15:14] == 2'b00) ? /* extrom */ {9'b0,addrlatch[13:0]} :
- (addrlatch[15:13] == 3'b101) ? {1'b1, 9'b0, addrlatch[12:0]} :
- (addrlatch == ADDR_PROGDATA) ? progaddr :
+ assign cr_A = (address[15:14] == 2'b00) ? /* extrom */ {9'b0,address[13:0]} :
+ (address[15:13] == 3'b101) ? {1'b1, 9'b0, address[12:0]} :
+ (address == ADDR_PROGDATA) ? progaddr :
23'b0;
reg [7:0] regbuf;
ADDR_PROGADDRM: if (wr) progaddrm <= data;
ADDR_PROGADDRL: if (wr) progaddrl <= data;
ADDR_PROGDATA: if (rd || wr) begin
- progaddr <= {progaddrh[6:0], progaddrm[7:0], progaddr[7:0]};
- {progaddrh[6:0], progaddrm[7:0], progaddr[7:0]} <= {progaddrh[6:0], progaddrm[7:0], progaddr[7:0]} + 23'b1;
+ progaddr <= {progaddrh[6:0], progaddrm[7:0], progaddrl[7:0]};
+ {progaddrh[6:0], progaddrm[7:0], progaddrl[7:0]} <= {progaddrh[6:0], progaddrm[7:0], progaddrl[7:0]} + 23'b1;
end
endcase
rdlatch <= rd;
{
int cs = 0;
- while (waitchar(10) == 1)
+ while (waitchar(100) == 1)
{
char c;
if (read(0, &c, 1) == 0)
exit(1);
}
- dowrite("\x1B" "A\x00\x00\x00...", 8);
+ dowrite("\x1B" "A\x00\x00\x00", 5);
fprintf(stderr, "Address sent\n");
- expect("A...", 4);
- while ((sz = read(rfd, buf+3, 128)) > 0)
+ expect("A", 1);
+ expect_no_chars();
+ while ((sz = read(rfd, buf+3, 255)) > 0)
{
buf[0] = 0x1B;
buf[1] = 'D';