自己做了一塊74HC595的IO擴(kuò)展板卡,出于靈活考慮,沒(méi)有都采用級(jí)聯(lián)的方式,而是2組多芯片級(jí)聯(lián)的結(jié)構(gòu)?;?a href="http://m.makelele.cn/v/tag/751/" target="_blank">STM32平臺(tái)設(shè)計(jì)。
結(jié)構(gòu)示意圖

74HV595內(nèi)部結(jié)構(gòu)圖
頭文件:
#ifndef __74HC595_H__
#define __74HC595_H__
#include "main.h"
typedef struct{
GPIO_TypeDef* GPIOx;
uint16_t GPIO_Pin;
}strHC595_Port;
//非級(jí)聯(lián)74HC595芯片組數(shù)
#define HC595_GROUP_NUMBER 2
/* 第一組芯片 */
//使能
#define HC595_OE1_RCC_GPIOX_EN __HAL_RCC_GPIOA_CLK_ENABLE()
#define HC595_OE1_GPIO GPIOA
#define HC595_OE1_PIN GPIO_PIN_4
//鎖存
#define HC595_RCLK1_RCC_GPIOX_EN __HAL_RCC_GPIOA_CLK_ENABLE()
#define HC595_RCLK1_GPIO GPIOA
#define HC595_RCLK1_PIN GPIO_PIN_6
//時(shí)鐘
#define HC595_SRCLK1_RCC_GPIOX_EN __HAL_RCC_GPIOA_CLK_ENABLE()
#define HC595_SRCLK1_GPIO GPIOA
#define HC595_SRCLK1_PIN GPIO_PIN_7
//清除
#define HC595_SRCLR1_RCC_GPIOX_EN __HAL_RCC_GPIOA_CLK_ENABLE()
#define HC595_SRCLR1_GPIO GPIOA
#define HC595_SRCLR1_PIN GPIO_PIN_5
//數(shù)據(jù)
#define HC595_DATA1_RCC_GPIOX_EN __HAL_RCC_GPIOC_CLK_ENABLE()
#define HC595_DATA1_GPIO GPIOC
#define HC595_DATA1_PIN GPIO_PIN_4
/* 第二組芯片 */
//使能
#define HC595_OE2_RCC_GPIOX_EN __HAL_RCC_GPIOA_CLK_ENABLE()
#define HC595_OE2_GPIO GPIOB
#define HC595_OE2_PIN GPIO_PIN_3
//鎖存
#define HC595_RCLK2_RCC_GPIOX_EN __HAL_RCC_GPIOB_CLK_ENABLE()
#define HC595_RCLK2_GPIO GPIOB
#define HC595_RCLK2_PIN GPIO_PIN_5
//時(shí)鐘
#define HC595_SRCLK2_RCC_GPIOX_EN __HAL_RCC_GPIOB_CLK_ENABLE()
#define HC595_SRCLK2_GPIO GPIOB
#define HC595_SRCLK2_PIN GPIO_PIN_6
//清除
#define HC595_SRCLR2_RCC_GPIOX_EN __HAL_RCC_GPIOB_CLK_ENABLE()
#define HC595_SRCLR2_GPIO GPIOB
#define HC595_SRCLR2_PIN GPIO_PIN_4
//數(shù)據(jù)
#define HC595_DATA2_RCC_GPIOX_EN __HAL_RCC_GPIOB_CLK_ENABLE()
#define HC595_DATA2_GPIO GPIOB
#define HC595_DATA2_PIN GPIO_PIN_7
extern void HC595_Init(void);
extern uint8_t HC595_write(uint8_t group,uint8_t nbit,uint32_t datas);
#endif /*__74HC595_H__*/
源文件:
#include "74HC595.h"
strHC595_Port HC595_OE_Port[HC595_GROUP_NUMBER]=
{
{HC595_OE1_GPIO,HC595_OE1_PIN},
{HC595_OE2_GPIO,HC595_OE2_PIN},
//元素個(gè)數(shù)與HC595_GROUP_NUMBER對(duì)應(yīng)
};
strHC595_Port HC595_RCLK_Port[HC595_GROUP_NUMBER]=
{
{HC595_RCLK1_GPIO,HC595_RCLK1_PIN},
{HC595_RCLK2_GPIO,HC595_RCLK2_PIN},
//元素個(gè)數(shù)與HC595_GROUP_NUMBER對(duì)應(yīng)
};
strHC595_Port HC595_SRCLK_Port[HC595_GROUP_NUMBER]=
{
{HC595_SRCLK1_GPIO,HC595_SRCLK1_PIN},
{HC595_SRCLK2_GPIO,HC595_SRCLK2_PIN},
//元素個(gè)數(shù)與HC595_GROUP_NUMBER對(duì)應(yīng)
};
strHC595_Port HC595_SRCLR_Port[HC595_GROUP_NUMBER]=
{
{HC595_SRCLR1_GPIO,HC595_SRCLR1_PIN},
{HC595_SRCLR2_GPIO,HC595_SRCLR2_PIN},
//元素個(gè)數(shù)與HC595_GROUP_NUMBER對(duì)應(yīng)
};
strHC595_Port HC595_DATA_Port[HC595_GROUP_NUMBER]=
{
{HC595_DATA1_GPIO,HC595_DATA1_PIN},
{HC595_DATA2_GPIO,HC595_DATA2_PIN},
//元素個(gè)數(shù)與HC595_GROUP_NUMBER對(duì)應(yīng)
};
//操作接口宏定義
#define HC595_OE_PIN(X) HC595_OE_Port[X].GPIO_Pin
#define HC595_OE_GPIO(X) HC595_OE_Port[X].GPIOx
#define HC595_OE_H(X) HAL_GPIO_WritePin(HC595_OE_GPIO(X), HC595_OE_PIN(X), GPIO_PIN_SET)
#define HC595_OE_L(X) HAL_GPIO_WritePin(HC595_OE_GPIO(X), HC595_OE_PIN(X), GPIO_PIN_RESET)
#define HC595_RCLK_PIN(X) HC595_RCLK_Port[X].GPIO_Pin
#define HC595_RCLK_GPIO(X) HC595_RCLK_Port[X].GPIOx
#define HC595_RCLK_H(X) HAL_GPIO_WritePin(HC595_RCLK_GPIO(X), HC595_RCLK_PIN(X), GPIO_PIN_SET)
#define HC595_RCLK_L(X) HAL_GPIO_WritePin(HC595_RCLK_GPIO(X), HC595_RCLK_PIN(X), GPIO_PIN_RESET)
#define HC595_SRCLK_PIN(X) HC595_SRCLK_Port[X].GPIO_Pin
#define HC595_SRCLK_GPIO(X) HC595_SRCLK_Port[X].GPIOx
#define HC595_SRCLK_H(X) HAL_GPIO_WritePin(HC595_SRCLK_GPIO(X), HC595_SRCLK_PIN(X), GPIO_PIN_SET)
#define HC595_SRCLK_L(X) HAL_GPIO_WritePin(HC595_SRCLK_GPIO(X), HC595_SRCLK_PIN(X), GPIO_PIN_RESET)
#define HC595_SRCLR_PIN(X) HC595_SRCLR_Port[X].GPIO_Pin
#define HC595_SRCLR_GPIO(X) HC595_SRCLR_Port[X].GPIOx
#define HC595_SRCLR_H(X) HAL_GPIO_WritePin(HC595_SRCLR_GPIO(X), HC595_SRCLR_PIN(X), GPIO_PIN_SET)
#define HC595_SRCLR_L(X) HAL_GPIO_WritePin(HC595_SRCLR_GPIO(X), HC595_SRCLR_PIN(X), GPIO_PIN_RESET)
#define HC595_DATA_PIN(X) HC595_DATA_Port[X].GPIO_Pin
#define HC595_DATA_GPIO(X) HC595_DATA_Port[X].GPIOx
#define HC595_DATA_H(X) HAL_GPIO_WritePin(HC595_DATA_GPIO(X), HC595_DATA_PIN(X), GPIO_PIN_SET)
#define HC595_DATA_L(X) HAL_GPIO_WritePin(HC595_DATA_GPIO(X), HC595_DATA_PIN(X), GPIO_PIN_RESET)
void HC595_delay_us(uint8_t t_us)
{
//修改為系統(tǒng)中對(duì)應(yīng)的微秒級(jí)延時(shí)函數(shù),根據(jù)實(shí)際需求可以換成更小的ns級(jí)延時(shí)
delay_us(t_us);
}
/*
*描述:初始化HC595_GROUP_NUMBER組芯片對(duì)應(yīng)的控制引腳
*/
void HC595_Init(void)
{
GPIO_InitTypeDef GPIO_InitStruct = {0};
uint8_t i = 0;
/* GPIO Ports Clock Enable */
//第一組芯片引腳時(shí)鐘
HC595_OE1_RCC_GPIOX_EN;
HC595_RCLK1_RCC_GPIOX_EN;
HC595_SRCLK1_RCC_GPIOX_EN;
HC595_SRCLR1_RCC_GPIOX_EN;
HC595_DATA1_RCC_GPIOX_EN;
//第二組芯片引腳時(shí)鐘
HC595_OE2_RCC_GPIOX_EN;
HC595_RCLK2_RCC_GPIOX_EN;
HC595_SRCLK2_RCC_GPIOX_EN;
HC595_SRCLR2_RCC_GPIOX_EN;
HC595_DATA2_RCC_GPIOX_EN;
/*Configure GPIO pin */
for(i=0; i
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。
舉報(bào)投訴
-
STM32
+關(guān)注
關(guān)注
2309文章
11162瀏覽量
373457 -
時(shí)鐘
+關(guān)注
關(guān)注
11文章
1971瀏覽量
134999 -
GPIO
+關(guān)注
關(guān)注
16文章
1328瀏覽量
56230 -
74HC595
+關(guān)注
關(guān)注
7文章
193瀏覽量
32546 -
擴(kuò)展板卡
+關(guān)注
關(guān)注
0文章
2瀏覽量
1294
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
熱點(diǎn)推薦
74HC595(串入并出)基本原理和使用例程
] ********************************************************************************* *通過(guò)本例程了解 74HC595(串入并出)基本原理和使用 * *3個(gè)I/O擴(kuò)展8個(gè)輸出,通過(guò)片選可以
發(fā)表于 07-13 02:48
74HC595芯片的作用是什么
74HC595是在單片機(jī)系統(tǒng)中常用的芯片之一他的作用就是把串行的信號(hào)轉(zhuǎn)為并行的信號(hào),常用在各種數(shù)碼管以及點(diǎn)陣屏的驅(qū)動(dòng)芯片, 使用74HC595可以節(jié)約單片機(jī)mcu的io口資源,用3個(gè)io
發(fā)表于 07-22 07:05
使用74HC595芯片真的能節(jié)省STM32的IO口嗎
使用74HC595芯片真的能節(jié)省STM32的IO口嗎?為什么要使用74HC595芯片呢?
發(fā)表于 11-25 06:36
單片機(jī)IO直連控制74HC595
最近在調(diào)74HC595,單片機(jī)IO直連控制74HC595,單片機(jī)輸出3.3v, 而74HC595是5v供電。發(fā)現(xiàn)74HC595輸出時(shí)好時(shí)壞,
發(fā)表于 12-02 07:20
74HC595怎么使用
一、74HC595使用方法74HC595的數(shù)據(jù)端Q0--Q7:八位并行輸出端,可以直接控制數(shù)碼管的8個(gè)段。Q7:級(jí)聯(lián)輸出端。將它接下一個(gè)595的DS端。DS:串行數(shù)據(jù)輸入端,級(jí)聯(lián)的話接上一級(jí)的Q7
發(fā)表于 12-07 06:46
如何實(shí)現(xiàn)74HC595驅(qū)動(dòng)數(shù)碼管顯示
?4、數(shù)碼管顯示數(shù)碼管驅(qū)動(dòng)電路采用2片74HC595芯片進(jìn)行IO擴(kuò)展,僅僅只需3Pin即可驅(qū)動(dòng)需要16位引腳的數(shù)碼管。74HC595是一個(gè)8位串行輸入、并行輸出的位移緩存器。只有對(duì)
發(fā)表于 12-07 07:29
74HC595多組芯片多組級(jí)聯(lián)代碼分享
?自己做了一塊74HC595的IO擴(kuò)展板卡,出于靈活考慮,沒(méi)有都采用級(jí)聯(lián)的方式,而是2組多芯片級(jí)聯(lián)的結(jié)構(gòu)?。基于STM32平臺(tái)設(shè)計(jì)?。?結(jié)構(gòu)示意圖7
發(fā)表于 12-07 06:43
MCU驅(qū)動(dòng)74hc595的方法
MCU驅(qū)動(dòng)74hc595下圖關(guān)于595數(shù)據(jù)手冊(cè)上的介紹,使用比較簡(jiǎn)單兩片級(jí)聯(lián)控制擴(kuò)展IO輸出端口,可以用最少三個(gè)GPIO控制16路輸出單片機(jī)驅(qū)動(dòng)59
發(fā)表于 02-08 06:04
基于單片機(jī)的74HC595驅(qū)動(dòng)靜態(tài)數(shù)碼管(IO端口輸出擴(kuò)展)【匯編】
基于單片機(jī)的74HC595驅(qū)動(dòng)靜態(tài)數(shù)碼管(IO端口輸出擴(kuò)展)【匯編】
發(fā)表于 12-31 10:35
?42次下載
基于單片機(jī)的74HC595驅(qū)動(dòng)靜態(tài)數(shù)碼管(IO端口輸出擴(kuò)展)【C語(yǔ)言】
基于單片機(jī)的74HC595驅(qū)動(dòng)靜態(tài)數(shù)碼管(IO端口輸出擴(kuò)展)【C語(yǔ)言】
發(fā)表于 12-31 10:35
?35次下載
基于單片機(jī)的74HC595驅(qū)動(dòng)靜態(tài)數(shù)碼管(IO端口輸出擴(kuò)展)
基于單片機(jī)的74HC595驅(qū)動(dòng)靜態(tài)數(shù)碼管(IO端口輸出擴(kuò)展)【C語(yǔ)言+匯編】
發(fā)表于 01-06 11:08
?29次下載
IO口擴(kuò)展芯片74HC165和74HC595的使用實(shí)例代碼免費(fèi)下載
IO口擴(kuò)展芯片,主要是解決單片機(jī)IO口太少。 74HC165:數(shù)據(jù)從并轉(zhuǎn)串 74HC595:數(shù)據(jù)從串轉(zhuǎn)并兩種芯片,都是通過(guò)時(shí)序電路,加上移
發(fā)表于 09-19 17:20
?51次下載
74HC595多組芯片多組級(jí)聯(lián)代碼
?自己做了一塊74HC595的IO擴(kuò)展板卡,出于靈活考慮,沒(méi)有都采用級(jí)聯(lián)的方式,而是2組多芯片級(jí)聯(lián)的結(jié)構(gòu)??;?b class='flag-5'>STM32平臺(tái)設(shè)計(jì)?。?結(jié)構(gòu)示意圖7
發(fā)表于 11-24 10:51
?58次下載
MCU驅(qū)動(dòng)74hc595
MCU驅(qū)動(dòng)74hc595下圖關(guān)于595數(shù)據(jù)手冊(cè)上的介紹,使用比較簡(jiǎn)單兩片級(jí)聯(lián)控制擴(kuò)展IO輸出端口,可以用最少三個(gè)GPIO控制16路輸出單片機(jī)驅(qū)動(dòng)59
發(fā)表于 12-05 10:36
?61次下載
基于STM32的74HC595 IO擴(kuò)展板卡設(shè)計(jì)
評(píng)論