MAX6950和MAX6951为2000位和16位共阴极LED显示驱动器,通过高速SPI接口控制。这些器件采用独特的多路复用方案,以最大限度地减少 LED 驱动器和 LED 面板之间的连接。MAXQ2000为高性能6951位RISC微控制器,集成SPI模块,提供LED驱动器和微控制器之间的简单接口。本应用笔记给出了MAXQ®汇编语言的示例代码,演示了如何使用MAXQ6950 SPI模块试验MAX《》/MAX《》功能。
硬件和软件要求
为了进行本应用笔记中描述的接口实验,需要MAX6951评估板(EV kit)、MAXQ2000评估板(包括MAX-IDE软件)、+5V电源(最小容量为200mA)和一台带有可用串行端口的PC。
硬件设置
MAX6951评估板跳线设置
为了断开评估板上电平转换器芯片的/CS、DIN和SCLK信号,切断连接JU1、JU2和JU2引脚3和4的走线。
MAXQ2000评估板跳线和DIP开关设置
将开关SW3 1-8设置为关闭位置。
JU1:连接引脚 1 和 2 JU2:连接引脚 1 和 2 JU3:连接引脚 1 和 2 JU4:打开
JU10:打开
JU11:开启 (MAXQ2000评估板由JTAG接口板供电,由+5V电源供电)
连接两个评估板,如图1所示。
图1.MAX6951评估板与MAXQ2000评估板的连接原理图
固件说明
本示例项目的完整固件文件可从Maxim网站下载,并可使用Maxim的集成开发和调试环境MAX-IDE进行编译,用于MAXQ系列微控制器。
下载:完整固件(ZIP,18.8k)
主.asm 文件
此文件是此示例项目的主要演示循环。它调用不同的例程来演示向MAX6951寄存器正确写入数据。固件依次演示以下MAX6951功能:
MAX6951 SPI接口初始化
在十六进制解码模式下,将0、1、2、...、A、B、C、D、E、F和8位小数(即点亮所有LED段)写入并显示到MAX0上所有数字的P1平面和P6951平面。
在免解码模式下,使用自定义内置字体书写和显示上述字母和其他可识别的字母,如H,L,P,Q,Y等。
LED 调光回路。该环路显示如何写入MAX6951强度寄存器以测试数字亮度控制。
扫描限位循环。此循环显示具有相同强度设置的 1 到 8 位数字。
注意:监视该过程以确保在扫描限制增加时亮度降低。
闪烁循环,此循环将不同的数字写入平面 P0 和平面 P1 的每个数字。它还使用快速闪烁模式来演示可在多个LED驱动器之间同步的段闪烁控制。
滚动循环,此循环从左到右和从右到左滚动文本消息 HELLO。
弹跳环,此环路在两个 LED 边缘之间弹跳 HELLO。
计数循环。最后一个循环显示了在十六进制解码模式和无解码模式下,如何设计一个显示,以计算经过的毫秒数。
max2000ev_6951.asm 文件
该文件包含使用MAXQ6951微控制器与MAX2000评估板通信的所有实用程序功能。主要功能有:
max6951_init:该功能将MAXQ2000设置为正确的SPI模式,以便与MAX6951通信。它使能SPI并初始化MAX6951,使其在显示面板上显示0个1。清单 <> 详细显示了此函数。
清单 1.MAX6951初始化代码示例
;******************************************************************************* ;* Function: max6951_init ;* ;* Sets the correct SPI modes for talking to the MAX6951, enables SPI, and ;* ;* initializes the MAX6951 to display 8 0s. ;* ;* Input: None. ;* ;* Output: None. ;* ;* Destroys: ACC, A[0] -- A[10], PSF ;* ;******************************************************************************* MAX6951_INIT: ; SET SPI BAUD RATE MOVE A[0], #2400H ; SYSTEM CLOCK IS 16,000,000 HZ MOVE A[1], #00F4H MOVE A[2], #4240H ; DESIRED BAUD RATE IS 1,000,000 HZ MOVE A[3], #000FH CALL SPI_SETBAUDRATE ; SET THE APPROPRIATE MODES FOR THE 6951 MOVE C, #SPI_IDLE_LOW ; IDLE = LOW CALL SPI_SETCLOCKPOLARITY MOVE C, #SPI_ACTIVE_EDGE ; ACTIVE = RISING EDGE CALL SPI_SETCLOCKPHASE MOVE C, #SPI_LENGTH_16 ; ALWAYS TRANSFER 16 BITS CALL SPI_SETCHARACTERLENGTH MOVE C, #SPI_MASTER_MODE ; MAXQ2000 IS THE MASTER, MAX6951 IS THE SLAVE CALL SPI_SETMODE ; ENABLE SPI MOVE C, #1 CALL SPI_ENABLE ; SHUTDOWN MAX6951 DISPLAY FIRST CALL MAX6951_SHUTDOWN ; SET MAX6951 IN HEXADECIMAL DECODE MODE MOVE ACC, #MAX6951REG_DECODE SLA4 SLA4 OR #0FFH ; HEXADECIMAL DECODE CALL MAX6951_TRANSMIT ; SET DISPLAY INTENSITY = 16/16 MOVE ACC, #MAX6951REG_INTENSITY SLA4 SLA4 OR #0FH ; INTENSITY = 16/16 CALL MAX6951_TRANSMIT ; SCAN LIMIT = 7 MOVE ACC, #MAX6951REG_SCANLIMIT SLA4 SLA4 OR #07H ; SCAN LIMIT = 7 CALL MAX6951_TRANSMIT RET
max6951_transmit:该函数向Max16发送寄存器地址和数据字节(6951位)。
max6951_set_all_n:这些函数将数字寄存器的平面 P0 和平面 P1 都设置为数字“n”。所有函数都有十六进制解码版本,没有解码版本。
max6951_e_d_s_d:此功能使能MAX6951显示,然后延时半秒,关断显示,然后延时100ms。
max6951_screenshot:这些功能将 HELLO 置于 8 位 LED 面板上的八个不同位置。
max6951_scroll_R_to_L:通过以不同的顺序显示屏幕截图,此函数在无解码模式下从右向左滚动 HELLO。
max6951_scroll_L_to_R:通过以不同的顺序显示屏幕截图,此功能在无解码模式下从左向右滚动HELLO。
max6951_bouncing:此功能在两个 LED 边缘之间反弹 HELLO。
font_lookup:给定十六进制格式的数字值,此例程在标准 7 段 LED 上查找在非解码模式下显示相同字体的值。
max6951_counting:此功能计算并显示经过的毫秒数;分辨率为 10 毫秒。清单 2 详细显示了代码。
清单 2.MAX6951计数代码示例
;******************************************************************************* ;* Function: max6951_counting ;* ;* This routine counts how many 10-milliseconds have elapsed and displays ;* ;* the value from 0000 to 9999 on LED digits 3-0(no way to blank leading digits). ;* ; The routine displays the same value on LED digits 7-4(by using no decode ;* ;* mode, individual leading digits can be blanked). ;* ;* Input: None ;* ;* Output: None ;* ;* Destroys: ACC, A[1] - A[4], A[9] ;* ;******************************************************************************* MAX6951_COUNTING: CALL MAX6951_SHUTDOWN CALL MAX6951_SET_ALL_0 ; SET ALL BITS OF DATA REGISTERS TO 0 MOVE ACC, #010FH ; HEXDECIMAL DECODE DIGITS 3-0, NO DEOCDE DIGITS 7-4 CALL MAX6951_TRANSMIT ; INITIALIZE THE COUNT TO 0 MOVE A[1], #0 ; A[1] => DIGIT 0 MOVE A[2], #0 ; A[2] => DIGIT 1 MOVE A[3], #0 ; A[3] => DIGIT 2 MOVE A[4], #0 ; A[4] => DIGIT 3 COUNT_LOOP: INCREASE_DIGIT3: MOVE ACC, A[4] ; PROCESS DIGIT 3 SUB #9 JUMP Z, INCREASE_DIGIT2 ; DIGIT 3 = 9, THERE IS CARRY OVER MOVE ACC, A[4] ; DIGIT 3 < 9, CONTINUE ADD #1 MOVE A[4], ACC CALL FONT_LOOKUP ; LOOK UP THE VALUE FOR THIS FONT ; STORE IT IN A[9], KEEP ACC UNCHANGED OR #6300H CALL MAX6951_TRANSMIT ; NO CARRY OVER, WRITE DIGIT 3 NEW VALUE MOVE ACC, A[9] ; WRITE THE NO DECODE VALUE TO DIGIT 7 OR #6700H CALL MAX6951_TRANSMIT JUMP DISPLAY_NUMBER INCREASE_DIGIT2: OR #6300H CALL MAX6951_TRANSMIT ; WRITE 0 TO DIGIT 3 REGISTER FIRST MOVE A[4], #0 ; SET DIGIT 3 BACK TO 0 MOVE ACC, #677EH ; NO DECODE VALUE FOR FONT '0' IS "7EH" CALL MAX6951_TRANSMIT ; WRITE 7EH TO DIGIT 7 REGISTER MOVE ACC, A[3] ; PROCESS DIGIT 2 SUB #9 JUMP Z, INCREASE_DIGIT1 ; DIGIT 2 = 9, THERE IS CARRY OVER MOVE ACC, A[3] ; DIGIT 2 < 9, CONTINUE ADD #1 MOVE A[3], ACC CALL FONT_LOOKUP ; LOOK UP THE VALUE FOR THIS FONT ; STORE IT IN A[9], KEEP ACC UNCHANGED OR #6200H CALL MAX6951_TRANSMIT ; NO CARRY OVER, WRITE DIGIT 2 NEW VALUE MOVE ACC, A[9] ; WRITE THE NO DECODE VALUE TO DIGIT 6 OR #6600H CALL MAX6951_TRANSMIT JUMP DISPLAY_NUMBER INCREASE_DIGIT1: OR #6200H CALL MAX6951_TRANSMIT ; WRITE 0 TO DIGIT 2 REGISTER FIRST MOVE A[3], #0 ; SET DIGIT 2 BACK TO 0 MOVE ACC, #667EH ; NO DECODE VALUE FOR FONT '0' IS "7EH" CALL MAX6951_TRANSMIT ; WRITE 7EH TO DIGIT 6 REGISTER MOVE ACC, A[2] ; PROCESS DIGIT 1 SUB #9 JUMP Z, INCREASE_DIGIT0 ; DIGIT 1 = 9, THERE IS CARRY OVER MOVE ACC, A[2] ; DIGIT 1 < 9, CONTINUE ADD #1 MOVE A[2], ACC CALL FONT_LOOKUP ; LOOK UP THE VALUE FOR THIS FONT ; STORE IT IN A[9], KEEP ACC UNCHANGED OR #6100H CALL MAX6951_TRANSMIT ; NO CARRY OVER, WRITE DIGIT 1 NEW VALUE MOVE ACC, A[9] ; WRITE THE NO DECODE VALUE TO DIGIT 5 OR #6500H CALL MAX6951_TRANSMIT JUMP DISPLAY_NUMBER INCREASE_DIGIT0: OR #6100H CALL MAX6951_TRANSMIT ; WRITE 0 TO DIGIT 1 REGISTER FIRST MOVE A[2], #0 ; SET DIGIT 1 BACK TO 0 MOVE ACC, #657EH ; NO DECODE VALUE FOR FONT '0' IS "7EH" CALL MAX6951_TRANSMIT ; WIRTE 7EH TO DIGIT 5 REGISTER MOVE ACC, A[1] ; PROCESS DIGIT 0 SUB #9 JUMP Z, COUNT_COMPLETE ; DIGIT 0 = 9, COUNTING IS OVER MOVE ACC, A[1] ; DIGIT 0 < 9, CONTINUE ADD #1 MOVE A[1], ACC CALL FONT_LOOKUP ; LOOK UP THE VALUE FOR THIS FONT ; STORE IT IN A[9], KEEP ACC UNCHANGED OR #6000H CALL MAX6951_TRANSMIT ; NO CARRY OVER, WRITE DIGIT 0 NEW VALUE MOVE ACC, A[9] ; WRITE THE NO DECODE VALUE TO DIGIT 4 OR #6400H CALL MAX6951_TRANSMIT DISPLAY_NUMBER: ; DISPLAY DIGIT 3-0 IN HEXADECIMAL DECODE MODE ; DIEPLAY DIGIT 7-4 IN NO DECODE MODE CALL MAX6951_ENABLE CALL MAX6951_10MS_DELAY JUMP COUNT_LOOP COUNT_COMPLETE: RET
maxq2000_spi.asm文件:该文件是配置和使用MAXQ2000的SPI模块的实用程序。该文件集成在MAX-IDE中;用户无需修改即可使用它。
divide32.asm 文件:这是 MAX-IDE 软件中提供的 32/32 位除法例程。
maxq2000.inc、maxq2000_spi.inc和max2000ev_6951.inc文件:包括MAXQ2000引脚定义和MAX6951寄存器定义的文件。
结论
MAX6951/MAX6950 SPI LED驱动器是易于使用的共阴极显示驱动器,通过SPI串行接口与微控制器接口。MAXQ系列微控制器提供了一个方便的集成SPI模块,通过SPI接口与LED驱动器通信。此处给出的示例代码可帮助用户了解如何使用MAX6951 LED特性。示例代码也可用于类似的基于MAXQ2000的应用开发。
审核编辑:郭婷
全部0条评论
快来发表一下你的评论吧 !