⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pwm.vhd

📁 基于vhdl的PWM发生器
💻 VHD
字号:
LIBRARY ieee;
USE ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity pwm is
	port(
		a:in std_logic;	--脉宽寄存器/分频寄存器选择.1-脉宽寄存器 ,0-分频寄存器
		countclk: in std_logic;--分频计数器计数信号
		rs: in std_logic;--分频计数器、PWM周期计数器清零信号
		load: in std_logic;--数据装载信号
		dat: in std_logic_vector(7 downto 0);--8位数据输入
		pwmout: out std_logic);--PWM信号输出
end pwm;
architecture work of pwm is
	signal mycounter,cmpdat,fenpindat,fenpincount:integer range 0 to 255;
	signal theout:std_logic;
begin
	dataload_block:process(load)
	begin
		if(load'event and load='1') then
			if a='1' then
				cmpdat<=conv_integer(dat);
			else
				fenpindat<=conv_integer(dat);
			end if;
		end if;
	end process;
	counter_block:process(countclk,rs)
	begin
		if (countclk'event and countclk='1') then
			if rs='0' then
				if fenpincount=0 then
						fenpincount<=fenpindat;
						mycounter<=mycounter+1;
						if cmpdat<mycounter then
							theout<='0';
							else
							theout<='1';
						end if;
					else
					fenpincount<=fenpincount-1;
				end if;
				else
				mycounter<=0;
				fenpincount<=fenpindat;
			end if;
		end if;
	end process;
	pwmout<=theout;
end work;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -