background image

Nvis 5586A 

 

 

 

Nvis Technologies Pvt. Ltd. 

152 

Program 36: 
Rotate Left with Carry. 

 

 

Address

 

Opcode

 

Mnemonic

 

Comment

 

0400 

F8 

CLC 

CLEAR CARRY FLAG 

0401 

B0 26 

MOV AL, 26 

COPY 26 IN AL 

0403 

B1 03 

MOV  CL,3 

 

0405 

D2 D0 

RCL AL,CL 

AL = 30  CF= 1 

0407 

88 06 00 05 

MOV  [0500], AL 

[500] = 30 

040B 

F4 

HLT 

HALT 

Содержание 5586A

Страница 1: ...Nvis 5586A Learning Material Ver 1 0 Designed Manufactured by 141 B Electronic Complex Pardesipura Indore 452 010 India Tel 91 731 4211500 Telefax 91 731 4202959 Toll free 1800 103 5050 E mail info n...

Страница 2: ...Nvis 5586A Nvis Technologies Pvt Ltd 2...

Страница 3: ...8 Memory Address Port Address 65 9 Subroutines 68 10 Serial Communication 95 11 MASM Macro Assembler 100 12 Sample Programs 104 13 On Board Interface 163 14 Parallel Communication between two Nvis 558...

Страница 4: ...packed up with powerful monitor in 128K Bytes of factory programmed EPROMS and 32K Bytes of Read Write Memory The total memory on the board is 144K Bytes The system has 72 programmable I O lines The...

Страница 5: ...ing three nos of 8255 Serial RS 232 C Interface using 8251 Interrupt 8 different level interrupt using 8259 Timer Counter Three 16 bit Timer Counter using 8253 Keyboard Display 105 IBM PC Keyboard 20x...

Страница 6: ...nly the mains cord designed for this instrument Ensure that the mains cord is suitable for your country Ground the Instrument This instrument is grounded through the protective earth conductor of the...

Страница 7: ...o provide internal timing 8086 is designed to operate in two modes Minimum and Maximum It can prefetches upto 6 instruction bytes from memory and queues them in order to speed up instruction execution...

Страница 8: ...ture of 8086 8086 has two blocks BIU and EU The BIU performs all bus operations such as instruction fetching reading and writing operands for memory and calculating the addresses of the memory operand...

Страница 9: ...BIU is free to look ahead in the program by prefetching the next sequential instruction These prefetching instructions are held in its FIFO queue With its 16 bit data bus the BIU fetches two instruct...

Страница 10: ...cycles to memory or I O and perform the operation specified by the instruction on the operands During the execution of the instruction the EU tests the status and control flags and updates them based...

Страница 11: ...and I O interface The minimum mode signal can be divided into the following basic groups address data bus status control interrupt and DMA Address Data Bus These lines serve two functions As an addres...

Страница 12: ...ata for I O devices and interrupt type codes from an interrupt controller Status signal The four most significant address lines A19 through A16 are also multiplexed but in this case with status signal...

Страница 13: ...M IO tells external circuitry whether a memory or I O transfer is taking place over the bus Logic 1 at this output signals a memory operation and logic 0 an I O operation The direction of data transfe...

Страница 14: ...RESET to logic 0 initializes the internal register of the 8086 and initiates a reset service routine DMA Interface signals The direct memory access DMA interface of the 8086 minimum mode consist of th...

Страница 15: ...bus cycle is to follow S2 S1 S0 are input to the external bus controller device the bus controller generates the appropriately timed command and control signals The 8288 chip receive the status signal...

Страница 16: ...f the 1 st three signals are the same as those in the minimum mode The signal MCE PDEN has 2 functions depending on the mode in which 8288 is operating The 8288 can either operate in I O bus mode or s...

Страница 17: ...he code 111 is output by the 8086 it is signaling that no bus activity is to take place The control outputs produced by the 8288 are DEN DT R and ALE These 3 signals provide the same functions as thos...

Страница 18: ...is used for monitor storage while RAM for user s program storage A system may contain I O devices The clock generator generates the clock from the crystal oscillator and then shapes it and divides to...

Страница 19: ...ding the address in T1 the processor sends the data to be written to the addressed location The data remains on the bus until middle of T4 state The WR becomes active at the beginning of T2 unlike RD...

Страница 20: ...previous cycle or during T1 state of the current cycle the CPU activates HLDA in the next clock cycle and for succeeding bus cycles the bus will be given to another requesting master The control of th...

Страница 21: ...ut depends upon the status of the IOB pin If IOB is grounded it acts as master cascade enable to control cascade 8259A else it acts as peripheral data enable used in the multiple bus configurations IN...

Страница 22: ...AMWC or AIOWC is activated from T2 to T4 and MWTC or IOWC is activated from T3 to T4 The status bit S0 to S2 remains active until T3 and become passive during T3 and T4 If reader input is not activat...

Страница 23: ...Nvis 5586A Nvis Technologies Pvt Ltd 23 Memory Read Timing in Maximum Mode...

Страница 24: ...ent registers The 8086 has a total of fourteen 16 bit registers including a 16 bit register called the status register with 9 of bits implemented for status and control flags Most of the registers con...

Страница 25: ...an be changed directly using POP instruction Data segment DS is a 16 bit register containing address of 64KB segment with program data By default the processor assumes that all data referenced by gene...

Страница 26: ...Nvis 5586A Nvis Technologies Pvt Ltd 26 All general registers of the 8086 microprocessor can be used for arithmetic and logic operations The general registers are...

Страница 27: ...Data register consists of two 8 bit registers DL and DH which can be combined together and used as a 16 bitregister DX When combined DL register contains the low order byte of the word and DH contain...

Страница 28: ...SF Set if the most significant bit of the result is set Zero Flag ZF Set if the result is zero Auxiliary carry Flag AF Set if there was a carry from or borrow to bits 0 3 in the AL register Parity Fl...

Страница 29: ...ddress formed by adding an 8 bit or 16 bit displacement with the content of any one of the registers BX BP SI and DI in the default either DS or ES segment Example MOV AX 50H BX 6 Indexed Addressing M...

Страница 30: ...Nvis 5586A Nvis Technologies Pvt Ltd 30...

Страница 31: ...Machine Control Instructions These instructions control the machine status NOP HLT WAIT and LOCK instructions belong to this class 6 Flag Manipulation Instructions All the instructions which directly...

Страница 32: ...ne by prefixing instructions with the DS CS SS or ES some registers and instructions by default may use the ES or SS segments instead of DS segment Word data can be located at odd or even byte boundar...

Страница 33: ...flow interrupt interrupts due to INT instructions etc Non Maskable Interrupt The processor 8086 has a non maskable interrupt input pin NMI that has the highest priority among the external interrupts T...

Страница 34: ...Nvis 5586A Nvis Technologies Pvt Ltd 34 the next instruction The status of the pending interrupts is checked at the end of each instruction cycle...

Страница 35: ...byte locations 2 Examine Modify the contents of any of internal register of 8086 3 Move a block of Data Program from one location to another location 4 Fill a particular memory area with a constant 5...

Страница 36: ...ernal SMPS Power Supply to AC Power and 5 pin connector to the left side on Nvis 5586A Kit 2 Switch on the Power Supply at the rear end of SMPS supply 3 A message NV5586A 8086 Mic Tr will come on disp...

Страница 37: ...terrupt an interrupt vector pointer must be provided on the data bus when INTA is active An interrupt Controller Circuit is provided to take care of more than one source of interrupt Co Processor 8087...

Страница 38: ...his is selected by a set of jumpers JP3 on the right hand side of the 8284 clock generator as shown below 1 2 MHz UPPER 2 CLK 3 1 MHz LOWER The Nvis 5586A is supplied in 2 MHz configuration Bus Contro...

Страница 39: ...and then converts them into a continuous serial data stream for transmission Simultaneously it can receive serial data stream and converts them into parallel data characters for the CPU This chip wil...

Страница 40: ...ular will automatically increase or decrease the words in order to move to different addresses The user can therefore continue sending in word code The cursor as to moved around or moved in the right...

Страница 41: ...n register stores the instruction code and address information which contains display data RAM and address of character generator RAM However the content of IR is only for read in but not read out The...

Страница 42: ...hat the LCD Modular is executing the inner instruction and no other instruction can be accepted The LCD Modular can only accept information when BF is lower to 0 Address Counter A C The address counte...

Страница 43: ...t character code The shape and code are shown in Table 2 and 3 Character Generator RAM C G RAM This RAM stores 8 different 5x7 dot of array character which allows the user to design the program When t...

Страница 44: ...Nvis 5586A Nvis Technologies Pvt Ltd 44 Character Codes Note 1 The CG RAM generates character patterns in accordance with the user s program 2 Shaded areas indicate 5x10 dot character patterns...

Страница 45: ...Nvis 5586A Nvis Technologies Pvt Ltd 45 Character code Note 1 The CG RAM generates character patterns in accordance with the user s program 2 Shaded areas indicate 5x10 dot character patterns...

Страница 46: ...or 5x7 Signifies a don t care bit Note 1 Character code bits 0 2 correspond to CG RAM address bits 3 5 Each of the 8 unique bit strings designated one of the 8 character patterns 2 A CG RAM address bi...

Страница 47: ...a light dot in the corresponding position on the display panel Functions of Reset Using the Internal Reset Circuit to Start LCD Modular internal has an automatic power supply to be used to RESET when...

Страница 48: ...Nvis 5586A Nvis Technologies Pvt Ltd 48 Diagram of module RESET power Instruction Set Note...

Страница 49: ...edetermined for each model Initialization by Instructions If the power conditions for the normal operation of the internal reset circuit are not satisfied LCD unit must be initialized by executing a s...

Страница 50: ...command will put the display data into a empty space code 20H address counter will be cleared to 0 When executing this command display OFF the cursor or the character blinking function will be moved...

Страница 51: ...be sent into the CPU and character generator RAM D D RAM Address Set Address counter and display data RAM have addresses which are driven by the binary 7 bit When this instruction is driven in data ca...

Страница 52: ...to be used again in order to read the D D RAM data The data can be read from the C G RAM D D RAM after the cursor shift After the execution of data address counter add 1 or minus 1 will be set in the...

Страница 53: ...ys used to move the cursor around Move one space to the left Delete the character at the cursor Simply Press the key A After the command an A will appear on the screen Assembly language can be input a...

Страница 54: ...screen if not switch off the power supply and re check The following steps are to be taken 1 Press the key A and the LCD display is as shown here 2 Now the user enter the segment address and effectiv...

Страница 55: ...ory location 2 Or user has entered the wrong instruction as follows As user press the Enter key then above instruction will not be converted into machine language And the cursor will point left side o...

Страница 56: ...hen this input assemble language will be converted into machine language in the memory and jump to the next memory location Now write the next instruction as follows In this way user can enter the who...

Страница 57: ...address If press the Enter or the ARROW UP key after specifying the address the memory will display the data Press ARROW UP key will allowed the address to ADD 8 and store in the memory as a whole nu...

Страница 58: ...is the starting position G Proceed to the address for execution The GO command which causes the machine language statements to be executed This command executes the loaded program and allows the user...

Страница 59: ...y allows interruption to be shown on the screen Note 1 During interrupt setting the address alternation register has commands like POP ES MOV DS AS etc to execute with the next command 2 The program w...

Страница 60: ...ther press G Enter and then F7 This indicates the third break point is at 0411 One can use any commands including Examine Register by pressing the key R Note In above figure observe the command R is a...

Страница 61: ...address and the desire address A RETURN key is then used to execute the changes Syntax The M key allows the data to be moved to another address The ending address must be greater than or equal to the...

Страница 62: ...process of the above program then the procedure is as follows 1 After entering the above program press F7 key then the menu will be displayed as follows 2 Press the Key T The screen displays as follo...

Страница 63: ...rd instruction is executed Press G key and next F7 key for further view the following results will be displayed 4th instruction is executed Press G key and next F7 key for further view the following r...

Страница 64: ...the machine code if the machine code is too long they will be continued on the second line The second line displays the assemble program and the process is completely done To see further press F7 key...

Страница 65: ...to modify at the address 0404 then following steps are to be taken a Press F7 key the menu will display b Press A key and enter the address 0404 as follows c Press Enter key and write the instruction...

Страница 66: ...OM MONITOR AREA ODD ROM EVEN ROM I O Address The addresses of the various chips in I O mapped in Nvis 5586A are as follows Device No Port No Selected Device 8255 I PPI 70 Port A 72 Port B 74 Port C 76...

Страница 67: ...NT2 INT3 have arranged the interrupt section and stack segment Stack Segment 0000 0390 BUFFER 0000 039B SYSTEM DATA 0000 93E0 BUFFER Only if needed 0000 0400 to 0000 7FFF USER S RAM AREA System Data o...

Страница 68: ...Use in interrupt system 5 Use in interrupt System 6 Set 0 to INTERRUPT and set 1 to TRACE 7 Set TRACE or INTERRUPT as TF flags timer 1 0000 03A0 Buffer of Interrupt setting 0000 03A5 0000 03AE Preser...

Страница 69: ...IF IT IS NOT AN ALPHABET THEN IT WILL BE SET TO C FLAGS AS 1 F000 F05C CALL FEB5 CONVERT THE INPUT SYMBOLS INTO ASCII CODE AND STORE IN AL IF IT IS NOT A SYMBOL THAN SET TO C FLAGS AS 1 F000 F060 CALL...

Страница 70: ...X INTO CURSOR ADDRESS F000 F094 CALL F39A WRITE THE HEXADECIMAL IN AX INTO BL DESIGNATED ADDRESS F000 F098 CALL FD4A READ IN 2 LETTERS FROM BL DESIGNATED POSITION CHANGE TO HEXADECIMAL AND STORE IN AX...

Страница 71: ...48 49 4A 4B 4C Alphabet B C D E F G H I J K L ASCII 4D 4E 4F 50 51 52 53 54 55 56 57 Alphabet M N O P Q R S T U V W FF80 ASCII 58 59 5A FF FF FF FF FF FF FF FF Alphabet X Y Z Symbols Code F000 FF90 FF...

Страница 72: ...ram catalog segment if the same segment subprogram RET is changed to different segment subprogram RET is changed to different segment subprogram RETF The user can therefore choose the different segmen...

Страница 73: ...ithout changing AL value Input Parameter The key in value is stored in AL Output Parameter If it is a numerical key transfer into the relative ASCII values store in AL and clear all flags All non nume...

Страница 74: ...tion BH will appoint BL where to start BH has to be smaller than 4 follows the address counter in the LCD modular When BL X0XX XXXX it is the first line when BL X1XX XXXX it is the second line The exa...

Страница 75: ...numerical ASCII code to 1 without changing the code of AL Input Parameter ASCII code of numbers that are stored in AL Output Parameter The ASCII code of the numbers in AL will be transferred to hexad...

Страница 76: ...it means an insert into hexadecimal DX means inserted numbers BH indicates inserted location Output Parameter DX is the code after insertion 19 CALL F000 F088 Write the AL code into cursor location in...

Страница 77: ...rical code the C Flag is set to 1 and is also taken back into AX before it returns BL instructed the number on the most left the rule ins the same as in 11 Input Parameter BL instructs the first word...

Страница 78: ...AY ON DISPLAY ON OFF ORDER 0 0409 9A 44 F0 00 F0 CALL F000 F044 CALL FOR WRITE IN INSTRUCTION SUBPROGRAM 0 040E 9A 50 F0 00 F0 CALL F000 F050 CALL FOR THE READ KEY IN 0 0413 9A 58 F0 00 F0 CALL F000 F...

Страница 79: ...display position B6 1 represents the second line B7 can be any number After entering subprogram it is automatically set to 1 B Bit BH as 00 instructs the cursor and the first word location first time...

Страница 80: ...OV AX 8088 INPUT PARAMETER OF SUBPROGRAM IS STORED IN BL AMONG 84 10000100 B0 TO B5 DISPLAY THE FIRST WORD ON THE MOST LEFT SIDE B6 AS 0 REPRESENTS THE 1ST LINE DISPLAY B7 CAN BE ANY VALUE THAT AUTOMA...

Страница 81: ...0E 0E PUSH CS 040F 1F POP DS SEGMENT VALUE SET FOR TABLE CHECKING 0410 BE 00 06 MOV SI 600 STARTING ADDRESS OF TABLE CHECKING IS STORED INTO SI 0413 B9 0A 00 MOV CX 0A STORE TABLE CHECKING LENGTH IN C...

Страница 82: ...Nvis 5586A Nvis Technologies Pvt Ltd 82 Example 5 To clear LCD display Address Opcode Mnemonic Comment 0400 9A 7C F0 00 F0 CALL F000 F07C CALL SUBROUTINE 0402 F4 HLT HALT...

Страница 83: ...bit hex data in ASCII code and display converted ASCII value Address Opcode Mnemonic Comment 0400 B0 45 MOV AL 45 MOVE 45 TO AL REGISTER 0402 9A 48 F0 00 F0 CALL F000 F048 CALL SUBROUTINE 0407 F4 HLT...

Страница 84: ...ss Opcode Mnemonic Comment 0400 B0 01 MOV AL 10 SHIFT CURSOR POSITION TO LEFT 0402 9A 44 F0 00 F0 CALL F000 F044 CALL SUBROUTINE 0407 F4 HLT HALT Address Opcode Mnemonic Comment 0400 B0 01 MOV AL 08 D...

Страница 85: ...arameter AL The code used for storing functional key DX Store the displayed numbers Address Opcode Mnemonic Comment 0400 9A 7C F0 00 F0 CALL F000 F07C CLEAR THE DISPLAY 0405 BB 00 00 MOV BX 0000 MOV 0...

Страница 86: ...in AL to HEX code the higher byte is stored in AH and the lower byte is stored in AL Address Opcode Mnemonic Comment 0400 B3 80 MOV AL 1A MOVE 1A IN AL REGISTER 0402 9A 78 F0 00 F0 CALL F000 F074 CALL...

Страница 87: ...Ltd 87 Example 10 To clear the first line of display Address Opcode Mnemonic Comment 0400 B3 80 MOV BL 80 INPUT PARAMETER OF SUBPROGRAM IS STORED IN BL B6 0 REPRESENTS 1ST LINE 0402 9A 78 F0 00 F0 CAL...

Страница 88: ...Example 11 To write the AL code into cursor location inside the address of the address counter Address Opcode Mnemonic Comment 0400 B0 67 MOV AL 67 MOVE 67 IN AL REGISTER 0402 9A 88 F0 00 F0 CALL F00...

Страница 89: ...logies Pvt Ltd 89 Example 12 To write the AX code into the cursor location Address Opcode Mnemonic Comment 0400 B0 67 MOV AX 4567 MOVE 4567 IN AX REGISTER 0403 9A 88 F0 00 F0 CALL F000 F088 CALL SUBRO...

Страница 90: ...he AX code into the BL indicated location of LCD BL indicates the first line or second line Address Opcode Mnemonic Comment 0400 B3 CC MOV BL CC MOVE CC IN BL REGISTER 0402 B8 67 45 MOV AX 4567 0405 9...

Страница 91: ...changing the HEX in AL to ASCII code ASCII code is stored in AL Conversion is valid for 30 39 H 41 46 H Address Opcode Mnemonic Comment 0400 B0 41 MOV AL 41 MOVE 41 IN AL REGISTER 0402 9A 70 F0 00 F0...

Страница 92: ...d 92 Example 15 Address Opcode Mnemonic Comment 0400 9A 4C F0 00F0 CALL F000 F04C CALL SUBROUTINE 0405 9A 88 F0 00F0 CALL F000 F088 CALL SUBROUTINE 040A 88 06 59 04 MOV 459 AL MOVE AL CONTENT IN MEMOR...

Страница 93: ...000 1101 LETTER BLINKING CURSOR OFF DISPLAY ON DISPLAY ON OFF ORDER 0 0409 9A 44 F0 00 F0 CALL F000 F044 CALL FOR WRITE IN INSTRUCTION SUBPROGRAM 0 040E 9A 50 F0 00 F0 CALL F000 F050 CALL FOR THE READ...

Страница 94: ...000 1101 LETTER BLINKING CURSOR OFF DISPLAY ON DISPLAY ON OFF ORDER 0 0409 9A 44 F0 00 F0 CALL F000 F044 CALL FOR WRITE IN INSTRUCTION SUBPROGRAM 0 040E 9A 50 F0 00 F0 CALL F000 F050 CALL FOR THE READ...

Страница 95: ...AL 0D COMMAND THAT DISPLAY ON OFF IS STORED IN AL0D 0000 1101 LETTER BLINKING CURSOR OFF DISPLAY ON DISPLAY ON OFF ORDER 0 0409 9A 44 F0 00 F0 CALL F000 F044 CALL FOR WRITE IN INSTRUCTION SUBPROGRAM...

Страница 96: ...uploading of the data between the computer and the other serial devices The user can communicate Nvis 5586A trainer with PC using software as below procedure mentioned First run the microprocessor la...

Страница 97: ...uctions given as below Example We are storing the program data of Nvis 5586A from 0000 0400 Starting address to 0000 04FF End address as an example to demonstrate the UPLOADING features 1 On Nvis 5586...

Страница 98: ...ponse window 5 After file transfer complete click on button Save File as depicted in above figure 6 Now your file is saved in the PC By this procedure one can upload data in PC Downloading The followi...

Страница 99: ...his is the 1st RAM location data will be received from the PC and this address will keep on incrementing on receipt of each Data Byte Press Enter key of trainer keyboard and then click on open button...

Страница 100: ...le process is repeated If the count is odd and the output is high the first clock pulse after the count is loaded decrements the count by 1 Subsequent clock pulses decrements the clock by 2 The time o...

Страница 101: ...ote We can write above file in any window or dos editor directly And change extension to ASM Step2 Save above file suppose file name ABC ASM in same folder where the assembler is saved Step3 Now do th...

Страница 102: ...SUCCESSFUL 0 WARNING 0 SERVE ERROR Note The ASM file should be in same folder where MASM assembler is placed Step4 Run LINK file in below mention format C LINK exe ABC No need to give any extension Th...

Страница 103: ...s C for continues Step 7 Window will open asking for 1 BIN to ASCII 2 ASCII to BIN Select no 1 for BIN to ASCII then ENTER from PC keyboard Step 8 Again window will open asking for Enter the BIN filen...

Страница 104: ...am for comparing two strings 10 Program for moving the string for one memory location to other location with changed segment address 11 To ADD two Binary numbers each 8 Bytes long 12 To find the maxim...

Страница 105: ...35 Rotate Right through Carry 36 Rotate Left with Carry 37 Software triggered strobe 8253 38 Write a program to calculate N3 N12 N22 32 bit integer value stored at 300 H and 304H respectively The resu...

Страница 106: ...nic Comment 400 B8 34 12 MOV AX 1234 LOAD 1234 IN AX 403 05 78 56 ADD AX 5678 ADD 5678 TO CONTENT OF AX 406 88 26 20 04 MOV 420 AH LOAD RESULT ON RAM LOCATION 420 40A 88 06 21 04 MOV 421 AL LOAD RESUL...

Страница 107: ...nemonic Comment 400 B8 43 43 MOV AX 4343 LOAD 4343 TO AX 403 2D 21 21 SUB AX 2121 SUB CONTENT OF AX TO 2121 406 88 26 20 04 MOV 420 AH LOAD RESULT ON RAM LOCATION 420 40A 88 06 21 04 MOV 421 AL LOAD R...

Страница 108: ...MOV BX BA98 LOAD BA98 TO BX 406 F7 E3 MUL BX 408 88 36 50 04 MOV 450 DH LOAD RESULT TO 450 MEMORY LOCATION 40c 88 16 51 04 MOV 451 dl LOAD RESULT TO 451 MEMORY LOCATION 410 88 26 52 04 MOV 452 AH LOA...

Страница 109: ...FF FF MOV CX FFFF LOAD DIVISOR TO CX 408 F7 F1 DIV CX 40B 88 26 50 04 MOV 450 AH LOAD RESULT TO 450 RAM LOCATION 40F 88 06 51 04 MOV 451 AL LOAD RESULT TO 451 RAM LOCATION 413 88 36 52 04 MOV 452 DH...

Страница 110: ...nemonic Comment 400 B8 30 00 MOV AX 30 MOVE DATA IN AX 403 05 30 00 ADD AX 30 ADD DATA TO CONTENT OF AX 406 88 C2 MOV DL AL MOVE LOWER 8 BIT OF AX IN TO LOWER 8 BIT OF DX 408 9A 78 F0 00 F0 CALL F000...

Страница 111: ...R 409 8B 04 MOV AX SI 40B 89 05 MOV DI AX 40D 46 INC SI INCREMENT SI 40E 47 INC DI INCREMENT DI 40F 49 DEC CX DECREMENT CX 410 75 F7 JNE 409 412 F4 HLT HALT Note Press F7 button of keyboard connected...

Страница 112: ...V CX 500 SIZE OF STRING IS STORE AT 500 LOCATION 404 8D 36 50 05 LEA SI 550 LOAD EFFECTIVE ADDRESS 408 8D 3E 00 06 LEA DI 600 LOAD EFFECTIVE ADDRESS 40C FC CLD CLEAR DIRECTION FLAG 40D F3 REP 40E A4 M...

Страница 113: ...ote Press F7 button of keyboard connected to techbook and then press D enter address from where data is to be entered press enter and start feeding data Input 500 04H Length of Array 501 35H Element t...

Страница 114: ...QUAL 412 88 06 00 MOV 600 AL STORE RESULT ON 600 LOCATION 416 F4 HLT 417 B0 00 MOV AL 00 419 88 06 00 06 MOV 600 AL STORE 0 RESULT ON 600 LOCATION IF NOT EQUAL 41D F4 HLT Note Press F7 button of keybo...

Страница 115: ...ith offset address 10H 4 100000000 400H 10000000000 Physical Address 500H 10100000000 10H 4 100000000 450H 10001010000 Physical Address 550H 10101010000 Address Opcode Mnemonics Comments 400 B8 10 00...

Страница 116: ...ND 0501 IN 16 BIT ACC I E 0500 AH 0501 AL 040C 11 05 ADC DI AX ADD THE CONTENTS MS BYTES OF 0508 0509 WITH THE CONTENTS LS BYTES OF 0500 0501 AND STORE THE RESULT IN LOCATION 0508 ONWARDS 040E 46 INC...

Страница 117: ...MATCH ABOVE IS EQUAL THEN BRANCH TO L 040C 8A 24 MOV AH SI ELSE MOVE THE CONTENTS OF 0500 INTO 8 BIT ACC I E A REAL NO IN AH 040E 46 INC SI POINT AT THE NEXT ADDRESS OF STRING 040F E0 F7 LOOPNE 0408...

Страница 118: ...S OF STRING 0411 73 06 JNB 0419 IF TWO BYTES ARE IS ABOVE THAT THE EQUAL OR 1ST BYTE SECOND BYTE BRANCH TO 1 0413 86 04 XCHG AL SI ELSE SECOND BYTE IS LESS THAN FIRST BYTE AND SWAP INTERCHANGE THE TWO...

Страница 119: ...Nvis 5586A Nvis Technologies Pvt Ltd 119 0502 20 0504 20 0503 25 0505 15 0504 28 0506 07 0505 15 0506 07 Note Memory location 0500 shows no of bytes to sort in descending order...

Страница 120: ...E 80 E2 0F AND DL 0F MS NIBBLE OF MULTIPLIER IS ZEROED 0411 8A 04 MOV AL SI FIRST ASCII NO OF STRING IN AL 0413 46 INC SI POINT AT THE NEXT LOCN IN STRING OF ASCII NOS 0414 24 0F AND AL 0F MS NIBBLE A...

Страница 121: ...IGITS ELSE 0425 F4 HLT HALT Note Press F7 button of keyboard connected to techbook and then press D enter address from where data is to be entered press enter and start feeding data For Example After...

Страница 122: ...S OF ADDRESS ACCESSED BY SI REG AND INCREMENT SI REG I E POINT AT THE NEXT ADDRESS LOCN 0411 80 E0 0F AND AL 0F MS NIBBLE OF AL CONTENTS IS ALSO ZEROED 0413 D5 0A AAD PERFORM THE FN AL AH OA AL AH 00...

Страница 123: ...Nvis 5586A Nvis Technologies Pvt Ltd 123 0502 33 050A 00 0503 34 050B 05 0504 35 050C 07 0505 36 050D 06 0506 31 050E 00 0507 32 050F 02...

Страница 124: ...HE NO OF BYTES IN THE STRING 0409 AC 1 LODSB LOAD AL WITH DATA BYTE ACCESSED BY SI REG AND INCREMENT THE ADDRESS LOCN IN SI REG 040A F6 D8 NEG AL THE CONTENTS OF AL ARE 2 S COMPLEMENTED 040C AA STOSB...

Страница 125: ...Nvis 5586A Nvis Technologies Pvt Ltd 125 0508 09 0608 F7 0509 0A 0609 F6 050A 0B 060A F5 050B 0C 060B F4 050C 0D 060C F3 050D 0E 060D F2 050E 0F 060E F1 050F 10 060F F0...

Страница 126: ...AT IN ASYNCHRONOUS MODE 0406 E6 02 OUT 02 AL 0408 B0 00 MOV AL 00 040A E6 02 OUT 02 AL 040C B0 4E MOV AL 4E 040E E6 51 OUT 51 AL 0410 B0 05 MOV AL 05 COMMAND INSTRUCTION FORMAT MAKE TRANSIT ENABLE AND...

Страница 127: ...E 2402 AND AL 02 0440 74FA JE 043C 0442 E4 50 IN AL 50 RECEIVED THE CHARACTER IN SECOND LINE 0444 9A 48 F0 00 F0 CALLF000 F048 0449 E2 F1 LOOP 043C 044B E9 C6 FF JMP0414 Execute using G 000 0400 and p...

Страница 128: ...AL 00 040A E6 02 OUT 02 AL 040C B0 4E MOV AL 4E MODE INSTRUCTION FORMAT IN ASYNCHRONOUS MODE 040E E6 51 OUT 51 AL 0410 B0 05 MOV AL 05 MAKE TRANSMIT ENABLE AND RECEIVE ENABLE HIGH 0412 E6 51 OUT 51 AL...

Страница 129: ...RACTER TO CRT TERMINAL 043D 59 POP CX 043E E2 E3 LOOP 0423 0440 B9 14 00 MOV CX 0014 0443 B3 80 MOV BL 80 0445 9A 78 F0 00 F0 CALL F000 F078 CLEAR THE FIRST LINE 044A 51 PUSH CX 044B 9A 50 F0 00 F0 CA...

Страница 130: ...E6 50 OUT 50 AL TRANSMIT THE CHARACTER TO CRT TERMINAL 0464 59 POP CX 0465 E2 E3 LOOP 044A 0467 E9 AA FF JMP 0414 Execute using G command from 0000 0400 and press any key of the Nvis 5586A keyboard t...

Страница 131: ...L 0417 B0 00 MOV AL 00 ICW2 COMMAND 0419 E6 31 OUT 31 AL 041B B0 01 MOV AL 01 ICW4 COMMAND 041D E6 31 OUT 31 AL 041F B0 FE MOV AL FE UNMASK IRQ0 0421 E6 31 OUT 31 AL 0423 9A 7C F0 00 F0 CALL F0000 F07...

Страница 132: ...F TABLE IS STORED IN SI 2018 B9 0D 00 MOV CX 000D TABLE LENGTH STORED IN CX 201B FC L3 CLD 201C AC LODSB 201D 9A 48 F0 00 F0 CALL F000 F048 INPUT AL DATA INTO LCD MODULATOR 2022 E2 F7 LOOP 201B 2024 C...

Страница 133: ...L 0402 B3 52 MOV BL 52 COPY 52 IN BL 0404 00 D8 ADD AL BL ADD AL AND BL ADDITION SAVE IN AL 0406 27 DAA DECIMAL ADJUST ACCUMULATOR 0407 88 06 50 04 MOV 450 AL MOVE AL DATA IN MEMORY LOCATION 450 040B...

Страница 134: ...0400 B0 38 MOV AL 38 COPY 38 IN AL 0402 B5 61 MOV CH 61 COPY 61 IN CH 0404 28 E8 SUB AL CH AL D7 CF 1 BORROW 0406 2F DAS DECIMAL ADJUST AFTER SUBTRACTION AL 77 AS D 9 D 6 7 CF 1 0407 88 06 50 04 MOV...

Страница 135: ...IN AX 40A 89 06 5004 MOV 450 AX MOVE AX DATA IN MEMORY LOCATION 450 40E F4 HLT HALT 0415 B8 55 55 MOV AX 5555 COPY 5555 IN AX 0418 89 06 70 04 MOV 470 AX MOVE AL DATA IN MEMORY LOCATION 470 41C F4 HLT...

Страница 136: ...FFF COPY FFFF H IN AX 040A 89 06 5004 MOV 450 AX MOVE AX DATA IN MEMORY LOCATION 450 040E F4 HLT 0415 B8 55 55 MOV AX 5555 COPY 5555 IN AX 0418 89 06 70 04 MOV 470 AX MOVE AX DATA IN MEMORY LOCATION 4...

Страница 137: ...RE WRITTEN INTO LCD 0415 0E PUSH CS 0416 1F POP DS SEGMENT VALUE SET FOR TABLE CHECKING 0417 BE 00 06 MOV SI 600 STARTING ADDRESS OF TABLE CHECKING IS STORED INTO SI 041A B9 0A 00 MOV CX 0A STORE TABL...

Страница 138: ...ED INTO SI 0463 B9 0A 00 MOV CX 0A STORE TABLE CHECKING LENGTH IN CX 0466 FC CLD CLEAR DIRECTIONAL FLAG 0467 AC LODSB READ IN DATA FROM TABLE CHECKING SECTION UNTIL AL 0468 9A 48 F0 00 F0 CALL F000 F0...

Страница 139: ...MMANDS IN AL ARE WRITTEN INTO LCD 0415 0E PUSH CS 0416 1F POP DS SEGMENT VALUE SET FOR TABLE CHECKING 0417 BE 00 06 MOV SI 600 STARTING ADDRESS OF TABLE CHECKING IS STORED INTO SI 041A B9 0A 00 MOV CX...

Страница 140: ...R DIRECTIONAL FLAG 0467 AC LODSB READ IN DATA FROM TABLE CHECKING SECTION UNTIL AL 0468 9A 48 F0 00 F0 CALL F000 F048 INPUT AL DATA INTO LCD MODULAR 046D E2 AE LOOP 041D CX NOT EQUAL TO 0 WOULD CONTIN...

Страница 141: ...DATA AVAILABLE IN MEMORY LOCATION 501 H RESULT STORED IN MEMORY LOCATION 501 0414 00 1E 01 05 ADD 501 BL ADD BL DATA AVAILABLE ON MEMORY LOCATION 501 H RESULT STORED IN MEMORY LOCATION 501 0418 22 06...

Страница 142: ...142 Program 26 Logical AND operation of two bytes Address Opcode Mnemonic Comment 0400 B0 38 MOV AL 38 COPY 38 IN AL 0402 B5 61 MOV CH 61 COPY 61 IN CH 0404 20 E8 AND AL CH AL 20 H 0406 88 06 00 05 M...

Страница 143: ...Ltd 143 Program 27 Logical OR operation of two bytes Address Opcode Mnemonic Comment 0400 B0 55 MOV AL 55 COPY 55 IN AL 0402 B5 AA MOV CH AA COPY AA IN CH 0404 08 E8 OR AL CH AL FF 0406 88 06 00 05 MO...

Страница 144: ...Technologies Pvt Ltd 144 Program 28 Logical NOT operation of two bytes Address Opcode Mnemonic Comment 0400 B0 55 MOV AL 55 COPY 55 IN AL 0402 F6 D0 NOT AL AL AA 0404 88 06 00 05 MOV 0500 AL 500 AA 0...

Страница 145: ...td 145 Program 29 Logical XOR operation of two bytes Address Opcode Mnemonic Comment 0400 B0 55 MOV AL 55 COPY 55 IN AL 0402 B5 AA MOV CH AA COPY AA IN CH 0404 08 E8 XOR AL CH AL FF 0406 88 06 00 05 M...

Страница 146: ...logies Pvt Ltd 146 Program 30 Shift logical left Address Opcode Mnemonic Comment 0400 B0 55 MOV AL 55 COPY 55 IN AL 0402 D0 E0 SHL AL 01 AL AA 0404 D0 E0 SHL AL 01 AL 54 0406 88 06 00 05 MOV 0500 AL 5...

Страница 147: ...ogies Pvt Ltd 147 Program 31 Shift logical right Address Opcode Mnemonic Comment 0400 B0 55 MOV AL 55 COPY 55 IN AL 0402 D0 E0 SHR AL 01 AL 2A 0404 D0 E0 SHR AL 01 AL 15 0406 88 06 00 05 MOV 0500 AL 5...

Страница 148: ...es Pvt Ltd 148 Program 32 Rotate Right without Carry Address Opcode Mnemonic Comment 0400 B0 54 MOV AL 5F COPY 5F IN AL 0402 D0 C8 ROR AL 01 AL AF 0404 D0 C8 ROR AL 01 AL D7 0406 88 06 00 05 MOV 0500...

Страница 149: ...logies Pvt Ltd 149 Program 33 Rotate Left without Carry Address Opcode Mnemonic Comment 0400 B0 5F MOV AL 5F COPY 5F IN AL 0402 B1 02 MOV CL 2 0404 D2 C0 ROL AL CL AL 7D 0406 88 06 00 05 MOV 0500 AL 5...

Страница 150: ...es Pvt Ltd 150 Program 34 Shift Arithmetic Right SAR Address Opcode Mnemonic Comment 0400 B0 5F MOV AL 5F COPY 5F IN AL 0402 D0 F8 SAR AL 01 AL 2F 0404 D0 F8 SAR AL 01 AL 17 0406 88 06 00 05 MOV 0500...

Страница 151: ...Program 35 Rotate Right through Carry Address Opcode Mnemonic Comment 0400 F8 CLC CLEAR CARRY FLAG 0401 B0 26 MOV AL 26 COPY 26 IN AL 0403 B1 03 MOV CL 3 0405 D2 DB RCR AL CL AL 84 CF 1 0407 88 06 00...

Страница 152: ...52 Program 36 Rotate Left with Carry Address Opcode Mnemonic Comment 0400 F8 CLC CLEAR CARRY FLAG 0401 B0 26 MOV AL 26 COPY 26 IN AL 0403 B1 03 MOV CL 3 0405 D2 D0 RCL AL CL AL 30 CF 1 0407 88 06 00 0...

Страница 153: ...ected but the subsequent period will reflect the new value The count will be inhibited while the gate input is low Reloading the counter register will restart counting beginning with the new number Ad...

Страница 154: ...its N12 value 2 Load N2 and calculate its N22 value 3 Add the two 4 Take the square root and store it in 308H location Address Opcode Mnemonic Comment Step 1 0200 9B BB 00 03 MOV BX 0300H BX POINTS TO...

Страница 155: ...Pvt Ltd 155 Step 4 0218 9B D9 FA FSQRT CALCULATE SQUARE ROOT OF N12 22 021B 9B BB 08 03 MOV BX 0308 LOAD BX WITH 0308 FOR STORING RESULT 021F DB 17 FST BX STORE THE RESULT TOS ON 0308 0221 9B FWAIT 02...

Страница 156: ...required for running the program 1 Enter the program from 0000 0200 location 2 Set up the data in memory location 300 and 304 N1 0300 09 00 00 00 N2 0304 04 00 00 00 3 Run the program by GO Command an...

Страница 157: ...e relation Sin P1 Z Sin Z The above problem is solved by calculating Z 2 then converting the degrees into radians and then calculating the tangents The resulting values of X and Y are used for calcula...

Страница 158: ...10 000 VALUE 0243 9B DF 06 04 03 FILD ARG 3 0248 9B DE C9 FMURP ST 0 10 000 SIN Z 024B 9B D9 FC FRND INT ROUND THE INTEGER 024E 9B DF 36 06 03 FSTP ARG4 STORE IT IN BCD FORM 0253 9B FWAIT 0254 A1 06 0...

Страница 159: ...igit 5 Execute the program for various values of Sin Z Input Output Sin Z AL AX 10 2756 Sin 16 2E 7193 Sin 46 3C 8660 Sin 60 56 9976 Sin 86 The stack operation on execution of each instruction 1 FLDI...

Страница 160: ...ST 0 ST 3 ST 0 X2 ST 1 X2 ST 2 X ST 3 Y ST 4 Z 180 11 FADDP ST 1 ST 0 ST 0 X2 Y2 ST 1 X ST 2 Y ST 3 Z 180 12 FDIVRP ST 0 X X2 Y2 ST 1 Y ST 2 Z 180 13 FMULRP ST 0 XY X2 Y2 ST 1 Z 180 14 FLD ST 0 ST 0 X...

Страница 161: ...Nvis 5586A Nvis Technologies Pvt Ltd 161 ST 0 10 000 X SIN Z 18 FRNDINT ST 0 Rounding the integer 19 FSTP AR G 4 The argument has the result...

Страница 162: ...Start MOV AL 55H MOVE ACC DATA 55H 0406 E6 70 OUT 70H AL OUT AT PA 0408 E6 72 OUT 72H AL OUT AT PB 040A E6 74 OUT 74H AL OUT AT PC 040C E8 0D 00 CALL DELAY1 040F B0 AA MOV AL 0AAH MOVE ACC DATA AAH 0...

Страница 163: ...4 Send a SOC and ALE Start of conversion by outputting 00 03 at Port address 02 5 Input from Port address 02 to check for EOC end of conversion at D0 6 Read the ADC 0809 by inputting from Port address...

Страница 164: ...H5 MOV AL 04H SELECT CHANNEL A4 0431 E8 25 00 CALL 0459 0434 B3 C0 MOV BL 0C0H SELECT LCD LOCATION 0436 E8 41 00 CALL 047A 0439 B0 05 CH6 MOV AL 05H SELECT CHANNEL A5 043B E8 1B 00 CALL 0459 043E B3 C...

Страница 165: ...CLEAR DB AH 7CH 0F0H 00H 0F0H CALL 0F000 F07C CLEAR LCD SCREEN 0479 C3 RET 047A B4 00 ATDAT MOVAH 00H PUT 00 IN AH 047C 9A 94 F0 00 F0 CALL F000 F094 0481 B9 55 05 MOV CX 0555H CALL DISPLAY ROUTINE 04...

Страница 166: ...been designed to give an output of 0 to 8 Volts The output of DAC 0800 is coming at Xout and Yout terminal After executing the below program RAMP OUTPUT is displayed in the CRO Program To generate Ra...

Страница 167: ...G PORT A B FOR OUTPUT 0402 E6 76 OUT 76H AL SETTING CW 0404 BE 1604 LOOP2 MOV SI 0416H PLACE SAMPLES IN MEMORY 0407 B1 24 MOV CL 24H 0409 8A 04 LOOP1 MOV AL SI GET WHATEVER IS AT 0416 040B E6 70 OUT 7...

Страница 168: ...9A 7C F000 F0 CALL F000 F07C CALL THE DISPLAY FUNCTION 040D B4 00 MOV AH 00 040F B3 80 MOV BL 80 0411 9A 94 F000 F0 CALL F000 F094 0416 E0 EB FF JMP 404 JUMP TO 404 LOCATION For receiver fill the prog...

Страница 169: ...st location indicates the starting address F000 0400 and the 2nd location indicates the end address 0400 of the memory area to be transmitted on to the Serial Port Change this to 0000 0400 to 04FF as...

Страница 170: ...Nvis 5586A Nvis Technologies Pvt Ltd 170...

Страница 171: ...n the board of Nvis 5586A are as follows Bus Connector CN1 Pin Signal 1 5V 2 5V 3 GND 4 GND 5 AD3 6 AD7 7 AD2 8 AD6 9 AD1 10 AD5 11 AD0 12 AD4 13 A8 14 A16 15 A7 16 A15 17 A6 18 A14 19 A5 20 A13 21 A4...

Страница 172: ...Nvis 5586A Nvis Technologies Pvt Ltd 172 36 ALE 37 S1 38 S0 39 HLDA 40 HOLD 41 INTA 42 INTR 43 READY 44 NMI 45 RESET OUT 46 RESET IN 47 CLK OUT 48 I O CS 49 MEM CS 50 MEM CS...

Страница 173: ...Nvis 5586A Nvis Technologies Pvt Ltd 173 RS 232C Serial Connector CN3 Pin Signal 1 NC 2 Rxd 3 Txd 4 DTR 5 GND 6 DSR 7 RTS 8 CTS 9 NC Power Supply Connector CN4 Pin Signal 1 5V 2 GND 3 12V 4 12V...

Страница 174: ...174 8255 I Connector CN5 Pin Signal 1 P1C4 2 P1C5 3 P1C2 4 P1C3 5 P1C0 6 P1C1 7 P1B6 8 P1B7 9 P1B4 10 P1B5 11 P1B2 12 P1B3 13 P1B0 14 P1B1 15 P1A6 16 P1A7 17 P1A4 18 P1A5 19 P1A2 20 P1A3 21 P1A0 22 P...

Страница 175: ...175 8255 II Connector CN6 Pin Signal 1 P2C4 2 P2C5 3 P2C2 4 P2C3 5 P2C0 6 P2C1 7 P2B6 8 P2B7 9 P2B4 10 P2B5 11 P2B2 12 P2B3 13 P2B0 14 P2B1 15 P2A6 16 P2A7 17 P2A4 18 P2A5 19 P2A2 20 P2A3 21 P2A0 22 P...

Страница 176: ...176 8255 III Connector CN7 Pin Signal 1 P3C4 2 P3C5 3 P3C2 4 P3C3 5 P3C0 6 P3C1 7 P3B6 8 P3B7 9 P3B4 10 P3B5 11 P3B2 12 P3B3 13 P3B0 14 P3B1 15 P3A6 16 P3A7 17 P3A4 18 P3A5 19 P3A2 20 P3A3 21 P3A0 22...

Страница 177: ...Nvis Technologies Pvt Ltd 177 8259 8253 Connector CN8 Pin Signal 1 IR0 2 IR1 3 IR2 4 IR3 5 IR4 6 IR5 7 IR6 8 IR7 9 CLK0 10 OUT0 11 GATE0 12 OUT1 13 GATE1 14 CLK1 15 ATE2 16 OUT2 17 CLK2 18 NC 19 G ND...

Страница 178: ...ode ADC Nvis 5586A works with inbuilt ADC support DAC Nvis 5586A works with inbuilt DAC support Pot P1 Variable input for Channel 0 of inbuilt ADC when Jumper JP3 pin 2 3 is shorted ADC Channels Input...

Страница 179: ...for 5V to RAM Short 2 3 for Battery Supply to RAM Factory setting Short 1 2 Short 1 2 for External ADC Input at Channel 0 Short 2 3 for Internal ADC Input at Channel 0 from POT P1 Factory setting Sho...

Страница 180: ...Nvis 5586A Nvis Technologies Pvt Ltd 180 SW1 OFF All switches from 1 4 by default When running External 8259 Interrupt Controller please modify switch positions as defined 1 ON 2 OFF 3 OFF 4 OFF...

Страница 181: ...and assembly language programs Ans The software developed using 1 s and 0 s are called machine language programs The software developed using mnemonics are called assembly language programs Q6 What is...

Страница 182: ...the system clock and each T State is precisely equal to one clock period Q14 List the components of microprocessor single board microcomputer based system Ans The microprocessor based system consists...

Страница 183: ...ruction can be divided into fetch and execute cycles The fetch cycle is executed to fetch the opcode from memory The execute cycle is executed to decode the instruction and to perform the work instruc...

Страница 184: ...riate signal at the interrupt pin then the interrupt is called Hardware interrupt Q34 What are the modes in which 8086 can operate Ans The 8086 can operate in two modes and they are minimum or uniproc...

Страница 185: ...are the functional units available in 8086 architecture Ans The bus interface unit and execution unit are the two functional units available in 8086 architecture Q43 List the segment registers of 808...

Страница 186: ...What is the need for interrupt controller Ans The interrupt controller is employed to expand the interrupt inputs It can handle the interrupt request from various devices and allow one by one to the p...

Страница 187: ...T Q59 Give some examples of input devices to microprocessor based system Ans The input devices used in the microprocessor based system are Keyboards DIP switches ADC Floppy disc etc Q60 What is scanni...

Страница 188: ...l in program execution Ans The program counter keeps track of program execution To execute a program the starting address of the program is loaded in program counter The PC sends out an address to fet...

Страница 189: ...modify the instrument 5 The non working of the instrument is to be communicated to us immediately giving full details of the complaints and defects noticed specifically mentioning the type and sr no o...

Страница 190: ...Flat No G 2 S 101 Bhagat Vatika North Civil Lines Jaipur 302006 Raj Mr P Pradhan Mobile 097998 10236 email jaipur scientech bz Lucknow First Floor 279 54 20 A Chuhar Singh Colony Pan Dariba Lucknow U...

Страница 191: ...Nvis 5586A Nvis Technologies Pvt Ltd 191 References http nptel iitm ac in courses http www cpu world com CPUs 8086 index html...

Отзывы: