Download presentation
Presentation is loading. Please wait.
Published byWillis Page Modified over 9 years ago
1
Programming the Microprocessor A Course in Microprocessor Electrical Engineering Dept. University of Indonesia
2
Data Conversions –Describes conversions between binary and ASCII –Binary data are removed from a register or memory and converted to ASCII for the video display
3
4 Converting from Binary to ASCII –Conversion from binary to ASCII is accomplished in two ways : by the AAM instruction if the number is less than 100 or by a series of decimal divisions (devide by 10) Data Conversions (cont’d)
4
–The algorithm for converting from binary to ASCII code is : Divide by the 10 and save the remainder on the stack as a significant BCD Digit Repeat step 1 until the quotient is a 0 Retrieve each remainder and add a 30H to convert to ASCII before displaying or printing –Example 7-27 illustrates a program that uses the procedure DISP that processes the binary value in AL (0-99) and display it on the video screen as decimalExample 7-27
5
Data Conversions (cont’d) 4 Converting from ASCII to Binary –The algorithm for converting from ASCII to binary is : Begin with a binary result of 0 Subtract 30H from the character typed on the keyboard to convert it to BCD Multiply the result by 10 and add the new BCD digit Repeat steps 2 and 3 until the character typed is not an ASCII-coded number –Example 7-29 illustrates a procedure (READN) used in a program that implements this algoritmExample 7-29
6
Data Conversions (cont’d) 4 Displaying and Reading Hexadecimal Data –Reading Hexadecimal Data see Example 7-30Example 7-30 –Displaying Hexadecimal Data see Example 7-31Example 7-31 4 Using Lookup Tables for Data Conversions –A lookup table is formed in the memory as a list of data that is referenced by a procedure to perform conversions –is used XLAT instruction
7
Data Conversions (cont’d) –Converting from BCD to 7-segment Code Example 7-32 illustrates a lookup table that contains the 7-segment codes for the numbers 0 to 9Example 7-32 –Using a Lookup Table to Access ASCII Data Example 7-33 shows a table that references ASCII- coded character strings located in the code segmentExample 7-33
8
Disk Files –Data are found stored on the disk in the form of files –The disk is organized in four main parts : the boot sector the file allocation table (FAT) the root directory the data storage 4 Disk Organization –Fig. 7-2 illustrates the organization of sectors and tracks on the surface of the diskFig. 7-2 –Fig. 7-3 shows the organization of data on a diskFig. 7-3
9
Disk Files (cont’d) –Files are usually accessed through DOS INT 21H function calls There are two ways to accesse a file using INT 21H : –uses a file control block –uses a file handle 4 Sequential File Access –All DOS files are sequential files
10
Disk Files(cont’d) –File Creation A file is created by the INT 21 H function call number 3CH The file name must be stored at a location addressed by DS:DX before calling the function CX must contain the attribute of the file (or subdirectory) created An ASCII-Z string is a character string that ends with a 00H or null character Example 7-37 lists a short procedure that creates the new file on the diskExample 7-37 Table 7-5 lists and defines the attribute bit positionsTable 7-5
11
Disk Files(cont’d) –Writing to a File Before writing to a file, the file must have been created or opened The file handle is used to refer to the file whenever data are written Function number 40H is used to write data to an opened or newly created file. In addition to loading a 40H into AH, we must also load BX = the file handle, CX = the number of bytes to be written, and DS:DX = the address of the area to be written to the disk ( see Example 7-38 and 7-39)Example 7-387-39
12
Disk Files(cont’d) –The File Pointer It is a 32-bit number that addresses any byte in a file Once a file is opened, the file pointer can be changed with the move file pointer function number 42H A file pointer can be moved : –from the start of the file (AL=00H) –from the current location (AL=01H) –from the end of the file (AL=02H) The distance moved by the file pointer is specified by registers CX and DX
13
Disk Files(cont’d) Register BX must contain the file handle before using function 42H to move the file pointer Example 7-40 shows a procedure that opens a file, moves the file pointer to the end of the file, writes 256 bytes of data, and then closes the fileExample 7-40 Fig. 7-5 shows how this is accomplished by creating a second file (see Example 7-41)Fig. 7-5Example 7-41 –Random Access Files Creating a Random Access File (see Example 7-42)Example 7-42 Reading and Writing a Record (see Example 7-43)Example 7-43
14
Example Programs 4 Calculator Program –This program demonstrates how data conversion plays an important part in many application programs (see Example 7-44)Example 7-44 4 Numeric Sort Program –Fig. 7-6 shows five numbers that are sorted with a bubble sortFig. 7-6 –Example 7-45 illustrates a program that accepts 10 numbers from the keyboard (0-65535)Example 7-45
15
Interrupt Hooks –Hooks are used to tap into or intercept the interrupt structure of the microprocessor –a special keystroke, called a hot key, can be detected when we hook into the keyboard interrupt –Whenever the hot-key is typed, a terminate and stay resident (TSR) program that performs a special task, can be accessed –see Example 7-48Example 7-48
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.