Program for initialize two row lcd, Assembly Language

Assignment Help:

init_lcd                        ;(this initialises a 2 row lcd)

    bcf     TRISA,0             ;PORTA bit 0 as an output (lcd RS pin)
    bcf     TRISA,1             ;PORTA bit 1 as an output (lcd R/W pin)
    bcf     TRISA,2             ;PORTA bit 2 as an output (lcd E pin)

    
    bcf     lcd_rs
    bcf     lcd_rw
    bcf     lcd_en
    movlw   b'00110000'         ;Instruction - function set. First of 3
    call    lcd_write
    call    Delay5              ;wait MORE THAN 4.1mS


    movlw   b'00110000'         ;Instruction - function set. Second of 3
    call    lcd_write
    movlw   .33                 ;wait MORE THAN 100uS [(33 x 3) +1 +1 + (1 x 2)] - measured 102uS on scope
    movwf   counta              ;1 cycle
    decfsz  counta              ;1 cycle until true then a 2 cycle
    goto    $-2                 ;2 cycle instruction

    movlw   b'00110000'         ;Instruction - function set. Third of 3
    call    lcd_write

    movlw   b'00111000'         ;8 bit data / 2 line display / 5x8 character font
    call    lcd_write
    call    busy

    movlw   b'00001111'         ;instruction bit / display on / cursor position on / blinking cursor on
    call    lcd_write
    call    busy

    movlw   b'00000001'
    call    lcd_write
    call    busy

    movlw   b'00000110'         ;increment cursor position by 1 / don't shift display
    call    lcd_write
    call    busy

    return  ;return from initialization routine

lcd_write

    movwf   lcd_data            ;data to port
    bsf     lcd_en              ;sets LCD enable pin high
    bcf     lcd_en              ;data is latched into lcd on high to low transition of E

    return

busy

    bsf     TRISC,7             ;was output when sending init data, now input to read busy flag
    bsf     lcd_rw              ;set high to read data from lcd
    bsf     lcd_en              ;enable
    btfsc   lcd_busy            ;is the busy flag low?
    goto    $-2                 ;no, go back and keep checking until it is
    bcf     lcd_en              ;busy flag now clear
    bcf     lcd_rw              ;set lcd back to write mode
    bcf     TRISC,7             ;port bit as an output again

    return
Delay30
        movlw   .30             ;delay 30mS
        goto    d0
Delay5
        movlw   .5              ;delay 5ms
d0      movwf   count1
d1      movlw   0xC7
        movwf   counta
        movlw   0x01
        movwf   countb
Delay_0
        decfsz  counta
        goto    $+6
        decfsz  countb
        goto    Delay_0
        decfsz  count1
        goto    d1

        retlw   .0              ;return from the delay routine


Related Discussions:- Program for initialize two row lcd

Dec-arithmetic instruction-microprocessor, DEC:  Decrement :- The decremen...

DEC:  Decrement :- The decrement instruction subtracts 1 from the contents of the particular memory location or register. All the conditions code flags except carry flag are affec

Instruction set of 8086-microprocessor, Instruction set of 8086 : The 8...

Instruction set of 8086 : The 8086/8088 instructions are categorized into the following major types. This section describes the function of each of the instructions with approp

PIC, LIST p=18f4550 #include org 0x0000 movlw 0x00 _________ movlw 0xFF ...

LIST p=18f4550 #include org 0x0000 movlw 0x00 _________ movlw 0xFF movwf PORTB end .

General data registers-microprocessor, General Data Registers Given fig...

General Data Registers Given figure indicate the register organization of 8086. The registers DX, CX, BX and AX are the general purpose 16-bit registers. AX is behaved as 16-bi

External hardware-interrupts-microprocessor, External Hardware-Interrupts ...

External Hardware-Interrupts External hardware-interrupts are generated by controllers of external devices or coprocessors and are connected to the processor pin for Non Mask a

Into-jmp-unconditional branch instruction-microprocessor, INTO : Interrupt...

INTO : Interrupt on Overflow:- It is executed, when the overflow flag OF is set. The new contents of IP and CS register are taken from the address 0000:0000 as described in INT

Architecture of file transfer, Explain the architecture of the file transfe...

Explain the architecture of the file transfer protocol ftp in terms of clients, servers, sockets

Modes of 8254-microprocessor, Modes of 8254 :   Mode 0 (Inter...

Modes of 8254 :   Mode 0 (Interrupt on Terminal Count)-GATE which value is 1 enables counting and GATE  which value is 0 disables counting, and GATE put not effect on

Third generation microprocessor, III rd Generation Microprocessor: T...

III rd Generation Microprocessor: The single 3rd generation microprocessor chip having 64-pins began with the introduction of 16-bit Intel 8086 in 1978. The other essential

Program to average ten 16-bit values, Write a MC68HC12 assembly language pr...

Write a MC68HC12 assembly language program to average ten 16-bit values that are stored starting at address $1100. Place the two-byte result at $1110. Use indexed addressing. Us

Write Your Message!

Captcha
Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd