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

Formulate the linear programming model , Print Media Advertising (PMA) has ...

Print Media Advertising (PMA) has been providing a contract to market Buzz Cola via newspaper ads in a main southern newspaper. Full-page ads in the weekday editions (Monday throug

Risc characteristics-microprocessor, RISC Characteristics : The  concep...

RISC Characteristics : The  concept  of  RISC  architecture  include  an  attempt  to  reduce  execution  time  by make  simple  the instruction set of the computer. The main c

Program, wap proram for bthe addition of two 3*3 matrix

wap proram for bthe addition of two 3*3 matrix

8251 programmable/communication interface-microprocessor, 8251 Programmable...

8251 Programmable/Communication Interface As an instance of a serial interface device let us suppose Intel's 8251 A programmable communication interfaces. The 8251A is diagram

Generating random number using 8086, I need to generate a random number bby...

I need to generate a random number bby using 8086 assembly language

String manipulation instruction-microprocessor, String Manipulation Instruc...

String Manipulation Instruction A series of words or data bytes are available in memory at consecutive locations, to be mention to individually or collectively, are known as by

Queue operation-microprocessor, Queue Operation :   RQ/CT0, RQ...

Queue Operation :   RQ/CT0, RQ/G1-Request/Grant:   These pins are utilized by other local bus masters, in themaximum mode, to force the processor to release the loca

Cache components-microprocessor, Cache components The cache sub-system ...

Cache components The cache sub-system may be divided into 3 functional blocks: Tag RAM, SRAM and theCache Controller. In real designs, these blocks can be implemented  by multi

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