# HEWLETT-PACKARD COMPANY LOGIC SYSTEMS DIVISION # HP 64000 Logic Development System SYSTEM RELEASE BULLETIN Part Number: 5958-6019 0287 Printed: FEBRUARY 1987 | SSSSS | | RRRRRR | | BBBBBB | | |-------|-----|--------|-----|--------|-----| | S | S | R | R | В | В | | S | | R | R | В | В | | SSS | SSS | RRF | RRR | BBBI | BBB | | | S | R | R | В | В | | S | S | R | R | В | В | | SSS | SSS | R | R | BBBI | BBB | #### SYSTEM RELEASE BULLETIN # 64000 Logic Development System #### MARCH 1987 This System Release Bulletin (SRB) documents all fixes and enhancements that are incorporated in the latest release of software for the 64000 Logic Development System. The SRB is provided as a benefit of Hewlett-Packard's Software Support Services. The five sections of the SRB are: SOFTWARE RELEASE CONTENTS - lists the new revision codes for the 64000 products. PRODUCT INDEX - lists product names and numbers which are included in this issue. KPR NUMBER INDEX - sequential list of SR numbers. KEYWORD INDEX - brief description of each SR. KNOWN PROBLEM REPORTS - the actual reports. # Software release contents | Product name | Product number | uu.ff | |----------------------|----------------|-------| | *64000-UX OP-ENV 300 | 648015004 | 01.40 | | *68000 EMUL 12.5 MHZ | | 01.01 | | *68000 EMULATION 300 | 642425004 | 01.00 | | *68008 EMULATION | 64244 | 01.01 | | *68010 EMUL 12.5 MHZ | 64245 | 01.01 | | *80186 EMULATION 300 | 642245004 | 01.00 | | *80286B ASSEMB | 64859 | 01.01 | | | 648598004 | 01.10 | | | 64859S001 | 01.10 | | | 642645004 | 01.00 | | | 642035004 | 01.00 | | *8086 DQ EMULATION | 64220 | 01.02 | | *8088 DQ EMULATION | 64221 | 01.02 | | *INVERSE ASSEMB | 64856 | 01.01 | | *INVERSE ASSEMB | 64856s004 | 01.00 | | *OPERATING SYSTEM | 64100 | 02.05 | | *OP_SYS HP-UX / 300 | 64883 | 01.00 | | *PROM PROGRAMMER 300 | 64501S004 | 01.00 | | | 64885 | 01.20 | | | 647905004 | 01.10 | | | 647908001 | 01.10 | | • | 646205004 | 01.00 | | | 648085004 | 01.20 | | | 64808S001 | 01.20 | | *Z80H EMULATION 300 | 642538004 | 01.00 | # Product index | Product name | Product number | Page | |---------------------|----------------|------| | 68000 EMUL 12.5 MHZ | 64243 | 1 | | 68008 EMULATION | 64244 | 4 | | 68010 EMUL 12.5 MHZ | 64245 | 7 | | 80286B ASSEMB | 64859 | 10 | | 80286B ASSEMB 300 | 648598004 | 12 | | 80286B ASSEMB 500 | 648598001 | 14 | | 8086 DQ EMULATION | 64220 | 16 | | 8088 DQ EMULATION | 64221 | 17 | | OPERATING SYSTEM | 64100 | 18 | # Report number index | Report # | page | Report # | page | Report # | page | Report # | page | |------------|------|------------|------|------------|------|------------|------| | 5000118455 | 1 | D200046300 | 16 | D200055400 | 14 | D200060384 | 5 | | 5000134627 | 1 | D200047753 | 2 | D200055426 | 12 | D200060400 | 8 | | 5000136259 | 1 | D200047795 | 7 | D200055434 | 14 | D200060418 | 6 | | 5000151043 | 17 | D200047803 | 4 | D200055459 | 12 | D200060426 | 9 | | D200038067 | 2 | D200050914 | 5 | D200055467 | 14 | D200062869 | 17 | | D200038075 | 7 | D200055244 | 3 | D200055483 | 12 | D200065763 | 17 | | D200038083 | 4 | D200055343 | 10 | D200060368 | 5 | D200065789 | 16 | | D200046045 | 4 | D200055368 | 11 | D200060376 | 8 | D200067553 | 18 | | D200046060 | 7 | D200055376 | 11 | - 1 | | | | # - 68000 EMUL 12.5 MHZ - | Keyword | Product number | uu.ff Description | Report # | page | |--------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----------------------| | ********none****** | 64243<br>64243<br>64243<br>64243<br>64243<br>64243 | 01.00 Incorrect Setting of the Interrupt Mask while in the Monitor. 01.00 Incorrect Inverse Assembly of Address Register Indirect with Index Mode. 01.00 Incorrect Disassembly of the MULU Instruction with Immediate Operand. 01.00 Inappropriate Error Message When Loading User Program Without Monitor 01.00 The "occurs" guided-syntax softkey is missing for certain commands. 01.00 Incorrect Inverse Assembly occurs with a Non-64302A Analyzer. | 5000118455<br>5000134627<br>5000136259<br>D200038067<br>D200047753<br>D200055244 | 1<br>1<br>2<br>2 | | | | - 68008 EMULATION - | | | | Keyword | Product number | uu.ff Description | Report # | page | | ********none****** | 64244<br>64244<br>64244<br>64244<br>64244<br>64244 | 01.00 Inappropriate Error Message When Loading User Program Without Monitor 01.00 Incorrect Setting of the Interrupt Mask while in the Monitor. 01.00 The "occurs" guided-syntax softkey is missing for certain commands. 01.00 "Store memory" command creates 16 bit wordsize rather than 8 bit 01.00 Incorrect Inverse Assembly of Address Register Indirect with Index Mode. 01.00 Incorrect Disassembly of the MULU Instruction with Immediate Operand. 01.00 Incorrect Inverse Assembly occurs with a Non-64302A Analyzer. | D200038083<br>D200046045<br>D200047803<br>D200050914<br>D200060368<br>D200060384<br>D200060418 | 4<br>4<br>5<br>5<br>5 | | | | - 68010 EMUL 12.5 MHZ - | | | | Keyword | Product number | uu.ff Description | Report # | page | | ********none****** | 64245<br>64245<br>64245<br>64245<br>64245<br>64245 | 01.00 Inappropriate Error Message When Loading User Program Without Monitor 01.00 Incorrect Setting of the Interrupt Mask while in the Monitor. 01.00 The "occurs" guided-syntax softkey is missing for certain commands. 01.00 Incorrect Inverse Assembly of Address Register Indirect with Index Mode. 01.00 Incorrect Disassembly of the MULU Instruction with Immediate Operand. 01.00 Incorrect Inverse Assembly occurs with a Non-64302A Analyzer. | D200038075<br>D200046060<br>D200047795<br>D200060376<br>D200060400<br>D200060426 | 7<br>7<br>8<br>8 | | | | - 80286B ASSEMB - | | | | Keyword | Product number | uu.ff Description | Report # | page | | CODE GENERATOR | 64859<br>64859<br>64859 | 01.00 Obj. code generated for arithmetic instr. are incorrect.<br>01.00 FSTENV instruction generates object code without required wait instr<br>01.00 FSTSW/FNSTSW function incorrectly with two-byte memory operand | D200055343<br>D200055368<br>D200055376 | 11 | | | | - 80286B ASSEMB - | | | | Keyword | Product number | uu.ff Description | Report # | page | | CODE GENERATOR | 64859S004<br>64859S004<br>64859S004 | 01.00 FSTSW/FNSTSW function incorrectly with two-byte memory operand 01.00 FSTENV instruction generates object code without required wait instr 01.00 Obj. code generated for arithmetic instr. are incorrect. | D200055426<br>D200055459<br>D200055483 | 12 | | | | - 80286B ASSEMB - | | | | Keyword | Product number | uu.ff Description | Report # | page | | CODE GENERATOR | 64859S001<br>64859S001<br>64859S001 | 01.00 FSTSW/FNSTSW function incorrectly with two-byte memory operand 01.00 FSTENV instruction generates object code without required wait instruction of the code generated for arithmetic instruction are incorrect. | D200055400<br>D200055434<br>D200055467 | 14 | # Keyword index ### - 8086 DQ EMULATION - | Keyword | Product number | uu.ff Description | Report # | page | | |----------------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------|--| | | 64220<br>64220 | 01.01 Single stepping a noninterruptible instruction causes a display skip. 01.01 Emulator would not recover from errors during display memory repetitive. | D200046300<br>D200065789 | 16<br>16 | | | | | - 8088 DQ EMULATION - | | | | | Keyword | Product number | uu.ff Description | Report # | page | | | ************* STATUS USER MEMORY | 64221<br>64221<br>64221 | 01.01 Store Memory is incorrect for some bock sizes. 01.01 Softkeys for segment status are set up incorrectly 01.01 Emulator would not recover from errors during display memory repetitive. | D200062869<br>5000151043<br>D200065763 | 17 | | | | | - OPERATING SYSTEM - | | | | | Keyword | Product number | uu.ff Description | Report # | page | | | HIGH SPEED LINK | 64100 | 02.04 On heavily loaded systems with HSL, DISC DOWN messages appear. | D200067553 | 18 | | Page: 1 Number: 5000118455 Product: 68000 EMUL 12.5 MHZ 64243 01.00 One-line description: Incorrect Setting of the Interrupt Mask while in the Monitor. Problem: In the monitor listing at line 162, the instruction "AND #0FEFFH, SR" is used to set the interrupt mask to level 6. This will work only if the mask was set to level 7 upon entry into the monitor. The following monitor entry points do not insure that the mask is preset to 7: SPECIAL\_ENTRY, SWBK\_ENTRY, and JSR\_ENTRY. The following monitor entry points will operate correctly: MONITOR\_ENTRY, JUMP\_ENTRY, and RESET\_ENTRY. For example, if the monitor is entered with the interrupt mask set to level 1, the "AND" instruction will clear the mask to 0, thus permitting all interrupts. The monitor should be changed to check the value of the mask upon entry, and then use the MOVE, OR, and/or AND instructions to set the mask to level 6. Temporary solution: Remove the AND instruction or precede it with an OR instruction to set the mask to level 6. Signed off 01/12/87 in release 301.01 Number: 5000134627 Product: 68000 EMUL 12.5 MHZ 64243 01.00 One-line description: Incorrect Inverse Assembly of Address Register Indirect with Index Mode. Problem: The assembler syntax of the address register indirect with index addressing mode is d(An,Rn). Rn (the index register) can be either an address or a data register. If the code uses an address register for Rn, the disassembler incorrectly displays the data register of the same number. Refer to the following example: Source Code: MOVE.W 0[A0,A1].D0 Disassembled Code: MOVE.W 000H[A0,D1.W],D0 -----incorrect value Note that the index register was incorrectly disassembled as D1 instead of A1. Signed off 01/12/87 in release 301.01 Number: 5000136259 Product: 68000 EMUL 12.5 MHZ 64243 01.00 One-line description: Incorrect Disassembly of the MULU Instruction with Immediate Operand. Problem: The MULU instruction (with an immediate operand) disassembles incorrectly if it is preceded by a long word instruction. The following example will illustrate the problem. - 68000 EMUL 12.5 MHZ - SRB detail reports as of 01/12/87 Page: 1) The assembler listing file: 001000 263C MOVE.L #10,D3 001002 00000000A 001006 C6FC 0005 MULU #5,D3 00100A 4E71 NOP 2) The disassembled code: 001000 MOVE.L #00000000AH,D3 001006 MULU.W #000054E71H,D3 Note that the immmediate operand of the MULU instruction is incorrect. The disassembler has included the two bytes following the MULU instruction (4E71) as a part of the immediate operand. This could cause the incorrect disassembly of instructions following the MULU instruction because the disassembler might get out of synch. Signed off 01/12/87 in release 301.01 Number: D200038067 Product: 68000 EMUL 12.5 MHZ 64243 01.00 One-line description: Inappropriate Error Message When Loading User Program Without Monitor Problem An error message appears on the status line if a user program is loaded into memory without having the monitor linked with it. This error message is: ERROR: One or more monitor variables not mapped to emulation memory The load is successful even though this error message appears. An error message should not appear because there is no error in the loading procedure. A more appropriate indicator that the monitor was not loaded into memory is desired. Signed off 01/12/87 in release 301.01 Number: D200047753 Product: 68000 EMUL 12.5 MHZ 64243 01.00 One-line description: The "occurs" guided-syntax softkey is missing for certain commands. Problem Temporary solution: If the "occurs" option is manually typed in the appropriate location, the trace command will operate correctly. - 68000 EMUL 12.5 MHZ - Page: 3 01.00 Signed off 01/12/87 in release 301.01 Number: D200055244 Product: 68000 EMUL 12.5 MHZ 64243 SRB detail reports as of 01/12/87 Number: D200038083 Product: 68008 EMULATION 64244 Page: 01.00 One-line description: Incorrect Inverse Assembly occurs with a Non-64302A Analyzer. #### Problem. "display memory mnemonic" shows incorrect inverse assembly when using a non-64302A analyzer and displaying memory above address OFFFFH. Given the code BSR.W 5000H located at address 5006EH, the mnemonic disassembly of memory at address 5006EH will show BSR.W 0000H. This failure occurs because the analyzer i.d. is being defaulted to a 64300A which only uses 16 address lines. Signed off 01/12/87 in release 301.01 One-line description: Inappropriate Error Message When Loading User Program Without Monitor #### Problem An error message appears on the status line if a user program is loaded into memory without having the monitor linked with it. This error message is: ${\sf ER\bar{R}OR}$ : One or more monitor variables not mapped to emulation memory The load is successful even though this error message appears. An error message should not appear because there is no error in the loading procedure. A more appropriate indicator that the monitor was not loaded into memory is desired. Signed off 01/12/87 in release 401.01 Number: D200046045 Product: 68008 EMULATION 64244 01.00 One-line description: Incorrect Setting of the Interrupt Mask while in the Monitor. #### Problem: In the monitor listing at line 163, the instruction "AND #0FEFFH,SR" is used to set the interrupt mask to level 6. This will work only if the mask was set to level 7 upon entry into the monitor. The following monitor entry points do not insure that the mask is preset to 7: SPECIAL\_ENTRY, SWBK\_ENTRY, and JSR\_ENTRY. The following monitor entry points will operate correctly: MONITOR\_ENTRY, JUMP\_ENTRY, and RESET\_ENTRY. For example, if the monitor is entered with the interrupt mask set to level 1, the "AND" instruction will clear the mask to 0, thus permitting all interrupts. The monitor should be changed to check the value of the mask upon entry, and then use the MOVE, OR, and/or AND instructions to set the mask to level 6. Temporary solution: Remove the AND instruction or precede it with an OR instruction to set the mask to level 6. Signed off 01/12/87 in release 401.01 Number: D200047803 Product: 68008 EMULATION 64244 01.00 One-line description: The "occurs" guided-syntax softkey is missing for certain commands. #### Problem Page: 5 64244 Temporary solution: If the "occurs" option is manually typed in the appropriate location. the trace command will operate correctly. Signed off 01/12/87 in release 401.01 Number: D200050914 Product: 68008 EMULATION 01.00 One-line description: "Store memory" command creates 16 bit wordsize rather than 8 bit Using the "store memory <ADDRESS> to <FILE>" command creates a word size of 16 bits. In contrast, the assembler/linker creates the correct wordsize of 8 bits in the absolute file. This causes problems when using the output of the "store memory" command for programming proms. Temporary solution: As a workaround you use the "list memory <ADDRESS> to <FILE>" command to create a listing file. Then modify it using a command file that creates exactly the same format as the "list rom to <FILE>". Use this modified listing file for programming the prom. Signed off 01/12/87 in release 401.01 Number: D200060368 Product: 68008 EMULATION 01.00 One-line description: Incorrect Inverse Assembly of Address Register Indirect with Index Mode. The assembler syntax of the address register indirect with index addressing mode is d(An,Rn). Rn (the index register) can be either an address or a data register. If the code uses an address register for Rn, the disassembler incorrectly displays the data register of the same number. Refer to the following example: Source Code: MOVE.W 0[A0.A1].D0 Disassembled Code: MOVE.W 000H[A0,D1.W],D0 ----incorrect value Note that the index register was incorrectly disassembled as D1 instead of Al. Signed off 01/12/87 in release 401.01 Number: D200060384 Product: 68008 EMULATION 64244 64244 01.00 One-line description: Incorrect Disassembly of the MULU Instruction with Immediate Operand. The MULU instruction (with an immediate operand) disassembles incorrectly if it is preceded by a long word instruction. The following example will illustrate the problem. - 68008 EMULATION - SRB detail reports as of 01/12/87 Page: 6 1) The assembler listing file: 001000 263C MOVE.L #10,D3 001002 00000000A 001006 C6FC 0005 MULU #5.D3 00100A 4E71 NOP 2) The disassembled code: 001000 MOVE.L #00000000AH.D3 001006 MULU.W #000054E71H,D3 Note that the immmediate operand of the MULU instruction is incorrect. The disassembler has included the two bytes following the MULU instruction (4E71) as a part of the immediate operand. This could cause the incorrect disassembly of instructions following the MULU instruction because the disassembler might get out of synch. Signed off 01/12/87 in release 401.01 Number: D200060418 Product: 68008 EMULATION 64244 01.00 One-line description: Incorrect Inverse Assembly occurs with a Non-64302A Analyzer. "display memory mnemonic" shows incorrect inverse assembly when using a non-64302A analyzer and displaying memory above address OFFFFH. Given the code BSR.W 5000H located at address 5006EH, the mnemonic disassembly of memory at address 5006EH will show BSR.W 0000H. This failure occurs because the analyzer i.d. is being defaulted to a 64300A which only uses 16 address lines. Signed off 01/12/87 in release 401.01 - 68008 EMULATION - Page: Number: D200038075 Product: 68010 EMUL 12.5 MHZ 64245 7 One-line description: Inappropriate Error Message When Loading User Program Without Monitor Problem An error message appears on the status line if a user program is loaded into memory without having the monitor linked with it. This error message is: ERROR: One or more monitor variables not mapped to emulation memory The load is successful even though this error message appears. An error message should not appear because there is no error in the loading procedure. A more appropriate indicator that the monitor was not loaded into memory is desired. Signed off 01/12/87 in release 501.01 Number: D200046060 Product: 68010 EMUL 12.5 MHZ 64245 01.00 One-line description: Incorrect Setting of the Interrupt Mask while in the Monitor. Problem In the monitor listing at line 166, the instruction "AND #0FEFFH, SR" is used to set the interrupt mask to level 6. This will work only if the mask was set to level 7 upon entry into the monitor. The following monitor entry points do not insure that the mask is preset to 7: SPECIAL\_ENTRY, SWBK\_ENTRY, and JSR\_ENTRY. The following monitor entry points will operate correctly: MONITOR\_ENTRY, JUMP\_ENTRY, and RESET\_ENTRY. For example, if the monitor is entered with the interrupt mask set to level 1, the "AND" instruction will clear the mask to 0, thus permitting all interrupts. The monitor should be changed to check the value of the mask upon entry, and then use the MOVE, OR, and/or AND instructions to set the mask to level 6. Temporary solution: Remove the AND instruction or precede it with an OR instruction to set the mask to level 6. Signed off 01/12/87 in release 501.01 Number: D200047795 Product: 68010 EMUL 12.5 MHZ 64245 01.00 One-line description: The "occurs" guided-syntax softkey is missing for certain commands. Problem: An error occurs in the guided-syntax softkeys. Specifically, the <occurs> softkey is missing when you give the command "trace about data XX". The softkeys that appear are <,> <status> <or> <only> <counting> & <br/> < - 68010 EMUL 12.5 MHZ - SRB detail reports as of 01/12/87 Page: Temporary solution: If the "occurs" option is manually typed in the appropriate location, the trace command will operate correctly. Signed off 01/12/87 in release 501.01 Number: D200060376 Product: 68010 EMUL 12.5 MHZ 64245 01.00 8 One-line description: Incorrect Inverse Assembly of Address Register Indirect with Index Mode. Problem The assembler syntax of the address register indirect with index addressing mode is d(An,Rn). Rn (the index register) can be either an address or a data register. If the code uses an address register for Rn, the disassembler incorrectly displays the data register of the same number. Refer to the following example: Source Code: MOVE.W 0[A0,A1].D0 Disassembled Code: MOVE.W 000H[A0,D1.W],D0 -----incorrect value Note that the index register was incorrectly disassembled as D1 instead of A1. Signed off 01/12/87 in release 501.01 Number: D200060400 Product: 68010 EMUL 12.5 MHZ 64245 01.00 One-line description: Incorrect Disassembly of the MULU Instruction with Immediate Operand. Problem The MULU instruction (with an immediate operand) disassembles incorrectly if it is preceded by a long word instruction. The following example will illustrate the problem. 1) The assembler listing file: 001000 263C MOVE.L #10,D3 001002 00000000A 001006 C6FC 0005 MULU #5,D3 00100A 4E71 NOP 2) The disassembled code: 001000 MOVE.L #00000000AH,D3 001006 MULU.W #000054E71H,D3 Note that the immmediate operand of the MULU instruction is incorrect. The disassembler has included the two bytes following the MULU instruction (4E71) as a part of the immediate operand. This could cause the incorrect disassembly of instructions following the MULU instruction because the disassembler might get out of synch. Signed off 01/12/87 in release 501.01 - 68010 EMUL 12.5 MHZ - Page: 9 01.00 Number: D200060426 Product: 68010 EMUL 12.5 MHZ 64245 Number: D200055343 Product: 80286B ASSEMB SRB detail reports as of 01/12/87 64859 10 01.00 Page: One-line description: Incorrect Inverse Assembly occurs with a Non-64302A Analyzer. #### Problem: "display memory mnemonic" shows incorrect inverse assembly when using a non-64302A analyzer and displaying memory above address OFFFFH. Given the code BSR.W 5000H located at address 5006EH, the mnemonic disassembly of memory at address 5006EH will show BSR.W 0000H. This failure occurs because the analyzer i.d. is being defaulted to a 64300A which only uses 16 address lines. Signed off 01/12/87 in release 501.01 Keywords: CODE GENERATOR One-line description: Obj. code generated for arithmetic instr. are incorrect. #### Problem: The object code produced for the arithmetic instructions FADD, FDIV, FDIVP, FDIVR, FDIVRP, FMUL, FSUB, FSUBP, FSUBR, FSUBRP is not correct. These problems occur only with the code generated for the 80287 coprocessor. The 8087 processor was changed in Feb. 1984. The opcodes generated are for 8087 processors manufactured prior to Feb. 1984. | instruc | tion | opcode - valid prior to FE | B. 1984 | |-----------------|----------------------|----------------------------|---------| | FADD<br>FDIV | | DCC1<br>DCF1 | | | FDIV | ST[3],ST | DCF3 | | | FDIVP<br>FDIVR | ST[4],ST | DEF4<br>DCF9 | | | FDIVR | ST[4],ST | DCFC | | | FDIVRP<br>FMUL | ST[1],ST | DEF9<br>DCC9 | | | FSUB | | DCE1 | | | FSUB<br>FSUBP | ST[1],ST<br>ST[2],ST | DCE2<br>DEE2 | | | FSUBR | , | DCE9 | | | FSUBR<br>FSUBRP | ST[1],ST<br>ST[1],ST | DCE9<br>DEE9 | | The pseudo instruction NEW\_8087 will cause the correct opcodes to be generated. This assembler should default to the new opcodes without the pseudo instruction. #### Temporary solution: The "NEW 8087" pseudo instruction should be included in any program using the 80287 arithmetic instructions. This pseudo instruction should precede all 80287 instructions. NEW ONOT ex. "80286B" | DEFC FDIVP ST[4],ST DEF1 FDIVR DCF4 FDIVR ST[4],ST DEF1 FDIVRP ST[1],ST DEC9 FMUL DEE9 FSUB | | NEM_808 | 1 | |---------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------|----------------------------------------------------------------------| | DEF9 | | PROG | | | | DEF9 DCFB DEFC DEF1 DCF4 DEF1 DEC9 DEE9 DCE9 | FDIV FDIVP FDIVR FDIVR FDIVR FDIVRP FMUL FSUB FSUB | ST[3],ST<br>ST[4],ST<br>ST[4],ST<br>ST[1],ST<br>ST[1],ST<br>ST[2],ST | - 80286B ASSEMB - Page: 11 Page 64859 64859 DEE1 DCE1 DEE1 FSUBR FSUBR FSUBR ST[1],ST FSUBRP ST[1],ST Signed off 01/12/87 in release 901.01 Number: D200055368 Product: 80286B ASSEMB 01.00 Keywords: CODE GENERATOR One-line description: FSTENV instruction generates object code without required wait instr Problem: The object code for the FSTENV instruction is missing the required wait instruction. The code generated is D936001A, it should be 9BD936001A, Temporary solution: Precede all FSTENV instructions with the WAIT instruction. Signed off 01/12/87 in release 901.01 Number: D200055376 Product: 80286B ASSEMB 01.00 Keywords: CODE GENERATOR One-line description: FSTSW/FNSTSW function incorrectly with two-byte memory operand Problem: FSTSW/FNSTSW (Store 80287 Status Word) instruction incorrectly results in Invalid Operand Error when used with two-byte memory operand. This instruction should accept a two-byte memory operand. Temporary solution: The FSTSW AX or FNSTSW AX versions of the FSTSW/FNSTSW instructions can be used followed immediately by the MOV mem.AX instruction. Signed off 01/12/87 in release 901.01 SRB detail reports as of 01/12/87 Page: 12 01.00 Number: D200055426 Product: 80286B ASSEMB 300 64859S004 Keywords: CODE GENERATOR One-line description: FSTSW/FNSTSW function incorrectly with two-byte memory operand Problem FSTSW/FNSTSW (Store 80287 Status Word) instruction incorrectly results in Invalid Operand Error when used with two-byte memory operand. This instruction should accept a two-byte memory operand. Temporary solution The FSTSW AX or FNSTSW AX versions of the FSTSW/FNSTSW instructions can be used followed immediately by the MOV mem, AX instruction. Number: D200055459 Product: 80286B ASSEMB 300 64859S004 01.00 Keywords: CODE GENERATOR One-line description: FSTENV instruction generates object code without required wait instr Problem: The object code for the FSTENV instruction is missing the required wait instruction. The code generated is D936001A, it should be 9BD936001A. Temporary solution: Precede all FSTENV instructions with the WAIT instruction. Number: D200055483 Product: 80286B ASSEMB 300 64859\$004 0 01.00 Keywords: CODE GENERATOR One-line description: Obj. code generated for arithmetic instr. are incorrect. Problem: The object code produced for the arithmetic instructions FADD, FDIV, PDIVP, PDIVR, PDIVRP, FMUL, FSUB, FSUBP, FSUBR, FSUBRP is not correct. These problems occur only with the code generated for the 80287 coprocessor. The 8087 processor was changed in Feb. 1984. The opcodes generated are for 8087 processors manufactured prior to Feb. 1984. | instruction | opcode - valid prior to FEB. 1984 | |-----------------|-----------------------------------| | FADD | DCC1 | | PDIV | DCF1 | | FDIV ST[3],ST | DCF3 | | FDIVP ST[4],ST | DEF4 | | FDIVR | DCF9 | | FDIVR ST[4],ST | DCFC | | FDIVRP ST[1],ST | DEF9 | | FMUL | DCC9 | | FSUB | DCE1 | | FSUB ST[1],ST | DCE2 | | FSUBP ST[2],ST | DEE2 | - 80286B ASSEMB - Page: 13 DCE9 FSUBR ST[1],ST FSUBRP ST[1],ST DCE9 DEE9 The pseudo instruction NEW 8087 will cause the correct opcodes to be generated. This assembler should default to the new opcodes without the pseudo instruction. Temporary solution: The "NEW\_8087" pseudo instruction should be included in any program using the 80287 arithmetic instructions. This pseudo instruction should precede all 80287 instructions. "80286B" ex. | | NEW_808 | NEW_8087 | | |-----------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--| | | PROG | | | | DEC1 DEF9 DCFB DEFC DEF1 DCF4 DEF1 DCC9 DEE9 DCE9 DEEA DEE1 DCE1 DCE1 | FADD FDIV FDIV FDIVR FDIVR FDIVR FDIVR FSUV FSUB FSUB FSUB FSUB FSUBR FSUBR FSUBR | ST[3],ST<br>ST[4],ST<br>ST[1],ST<br>ST[1],ST<br>ST[2],ST<br>ST[1],ST<br>ST[1],ST | | | | | | | SRB detail reports as of 01/12/87 Page: 14 Number: D200055400 Product: 80286B ASSEMB 500 64859S001 01.00 Keywords: CODE GENERATOR One-line description: FSTSW/FNSTSW function incorrectly with two-byte memory operand Problem: FSTSW/FNSTSW (Store 80287 Status Word) instruction incorrectly results in Invalid Operand Error when used with two-byte memory operand. This instruction should accept a two-byte memory operand. Temporary solution: The FSTSW AX or FNSTSW AX versions of the FSTSW/FNSTSW instructions can be used followed immediately by the MOV mem, AX instruction. Number: D200055434 Product: 80286B ASSEMB 500 64859S001 01.00 Keywords: CODE GENERATOR One-line description: FSTENV instruction generates object code without required wait instr The object code for the FSTENV instruction is missing the required wait instruction. The code generated is D936001A, it should be 9BD936001A. Temporary solution: Precede all FSTENV instructions with the WAIT instruction. Number: D200055467 Product: 80286B ASSEMB 500 64859S001 01.00 Keywords: CODE GENERATOR One-line description: Obj. code generated for arithmetic instr. are incorrect. The object code produced for the arithmetic instructions FADD, FDIV, FDIVP, FDIVR, FDIVRP, FMUL, FSUB, FSUBP, FSUBR, FSUBRP is not correct. These problems occur only with the code generated for the 80287 coprocessor. The 8087 processor was changed in Feb. 1984. The opcodes generated are for 8087 processors manufactured prior to Feb. 1984. | instruc | tion | opcode - valid prior to FEB | . 1984 | |---------------------------------------------------------------------------|----------------------------------------------|-------------------------------------------------------------|--------| | FADD<br>FDIV<br>FDIVP<br>FDIVR<br>FDIVR<br>FDIVRP<br>FMUL<br>FSUB<br>FSUB | ST[3],ST<br>ST[4],ST<br>ST[4],ST<br>ST[1],ST | DCC1 DCF1 DCF3 DEF4 DCF9 DCFC DEF9 DCC9 DCC9 DCC9 DCC1 DCC2 | | | FSUBP | ST[2],ST | DEE2 | | Page: 15 **FSUBR** DCE9 FSUBR ST[1],ST FSUBRP ST[1],ST DCE9 DEE9 The pseudo instruction NEW 8087 will cause the correct opcodes to be generated. This assembler should default to the new opcodes without the pseudo instruction. Temporary solution: The "NEW\_8087" pseudo instruction should be included in any program using the 80287 arithmetic instructions. This pseudo instruction should precede all 80287 instructions. NEW SOST ex. "80286B" | | NEW_OUG | 1 | |-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | | PROG | | | DEC1 DEF9 DCFB DEFC DEF1 DCF4 DEF1 DEC9 DEE9 DEE9 DEEA DEE1 DCE1 DEE1 | FADD<br>FDIV<br>FDIVP<br>FDIVR<br>FDIVR<br>FDIVR<br>FDIVR<br>FMUL<br>FSUB<br>FSUB<br>FSUBR<br>FSUBR<br>FSUBR<br>FSUBR | ST[3],ST<br>ST[4],ST<br>ST[4],ST<br>ST[1],ST<br>ST[2],ST<br>ST[2],ST<br>ST[1],ST<br>ST[1],ST | SRB detail reports as of 01/12/87 Page: 16 Number: D200046300 Product: 8086 DQ EMULATION One-line description: Single stepping a noninterruptible instruction causes a display skip. Signed off 01/12/87 in release 001.02 Number: D200065789 Product: 8086 DQ EMULATION 64220 01.01 01.01 Keywords: USER MEMORY One-line description: Emulator would not recover from errors during display memory repetitive. The problem occurs when displaying user memory repetitively. An error condition such as slow clock or guarded memory access would cause the 64000 station to reboot or to display extraneous data at the top of the screen. When the screen had been written to at the top, the only action to delete the characters was resetting the station. Temporary solution: There is no workaround other than avoiding the error conditions during a repetitive display of user memory. Signed off 01/12/87 in release 001.02 Page: 17 01.01 SRB detail reports as of 01/12/87 Page: 64100 Number: 5000151043 Product: 8088 DQ EMULATION Number: D200067553 Product: OPERATING SYSTEM 18 02.04 Keywords: STATUS 64221 Keywords: HIGH SPEED LINK One-line description: Softkeys for segment status are set up incorrectly Temporary solution: Use the binary form for segment status specification instead of the softkeys. Signed off 01/12/87 in release 101.02 Number: D200062869 Product: 8088 DQ EMULATION 64221 01.01 One-line description: Store Memory is incorrect for some bock sizes. Signed off 01/12/87 in release 101.02 Number: D200065763 Product: 8088 DQ EMULATION 64221 01.01 Keywords: USER MEMORY One-line description: Emulator would not recover from errors during display memory repetitive. The problem occurs when displaying user memory repetitively. An error condition such as slow clock or guarded memory access would cause the 64000 station to reboot or to display extraneous data at the top of the screen. When the screen had been written to at the top, the only action to delete the characters was resetting the station. Temporary solution: There is no workaround other than avoiding the error conditions during a repetitive display of user memory. Signed off 01/12/87 in release 101.02 One-line description: On heavily loaded systems with HSL, DISC DOWN messages appear. On a heavily loaded 64000 system with a High Speed Link, the message "BUS DISC 0 DOWN" may be frequently appearing on the 64000 status line. It happens most frequently with a SS/80 or CS/80 system disc. Signed off 01/12/87 in release 002.05