




已阅读5页,还剩11页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
基于ISE的SPI接口的仿真设计一、SPI介绍SPI总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息。外围设置FLASHRAM、网络控制器、LCD显示驱动器、A/D转换器和MCU等。SPI总线系统可直接与各个厂家生产的多种标准外围器件直接接口,该接口一般使用4条线:串行时钟线(SCK)、主机输入/从机输出数据线MISO、主机输出/从机输入数据线MOST和低电平有效的从机选择线SS(有的SPI接口芯片带有中断信号线INT或INT、有的SPI接口芯片没有主机输出/从机输入数据线MOSI)。SPI的通信原理很简单,它以主从方式工作,这种模式通常有一个主设备和一个或多个从设备,需要至少4根线,事实上3根也可以(单向传输时)。也是所有基于SPI的设备共有的,它们是SDI(数据输入),SDO(数据输出),SCK(时钟),CS(片选)。 (1)MOSI 主设备数据输出,从设备数据输入 (2)MISO 主设备数据输入,从设备数据输出 (3)SCLK 时钟信号,由主设备产生 (4)CS 从设备使能信号,由主设备控制其中CS是控制芯片是否被选中的,也就是说只有片选信号为预先规定的使能信号时(高电位或低电位),对此芯片的操作才有效。这就允许在同一总线上连接多个SPI设备成为可能。接下来就负责通讯的3根线了。通讯是通过数据交换完成的,这里先要知道SPI是串行通讯协议,也就是说数据是一位一位的传输的。这就是SCK时钟线存在的原因,由SCK提供时钟脉冲,SDI,SDO则基于此脉冲完成数据传输。数据输出通过 SDO线,数据在时钟上升沿或下降沿时改变,在紧接着的下降沿或上升沿被读取。完成一位数据传输,输入也使用同样原理。这样,在至少8次时钟信号的改变(上沿和下沿为一次),就可以完成8位数据的传输。 要注意的是,SCK信号线只由主设备控制,从设备不能控制信号线。同样,在一个基于SPI的设备中,至少有一个主控设备。这样传输的特点:这样的传输方式有一个优点,与普通的串行通讯不同,普通的串行通讯一次连续传送至少8位数据,而SPI允许数据一位一位的传送,甚至允许暂停,因为SCK时钟线由主控设备控制,当没有时钟跳变时,从设备不采集或传送数据。也就是说,主设备通过对SCK时钟线的控制可以完成对通讯的控制。SPI还是一个数据交换协议:因为SPI的数据输入和输出线独立,所以允许同时完成数据的输入和输出。不同的SPI设备的实现方式不尽相同,主要是数据改变和采集的时间不同,在时钟信号上沿或下沿采集有不同定义,具体请参考相关器件的文档。在点对点的通信中,SPI接口不需要进行寻址操作,且为全双工通信,显得简单高效。在多个从设备的系统中,每个从设备需要独立的使能信号,硬件上比I2C系统要稍微复杂一些。二、SPI工作模式SPI由工作方式的不同,可分为两种模式:主模式和从模式(1) 主模式将Master的数据传送给Slave,8位数据传送,传送完毕,申请中断,如图所示:MOSIMOSISCLKSCLK SPI工作主模式(2) 从模式此时,从控制器从SIMO引脚接收串行数据并把数据移入自身移位寄存器的最低位或最高位。要注意的是,其是在主控制器输出时钟SCLK的控制下,在SCLK的上升沿或者下降沿读出一个数据输出给主设备。其传播模型如下图所示:MISOCSSCLKMISOCSSCLKSPI工作从模式须注意的是,主设备可以再在任意时刻起动数据发送,因为它控制着SCLK信号,而在从模式下,从控制器要发送数据,必须要用先设置片选信号以确保使能端CS输入允许。三、SPI传输模式SPI 的工作模式分为主模式和从模式,二者都需要在 SCK 的作用下才能工作;但主模式不需要 CS 信号,而从模式必须在 CS 信号有效的情况下才能完成。不论是在主模式下还是在从模式下,都要在时钟极性(CPOL)和时钟相位(CPHA)的配合下才能有效地完成一次数据传输。其中,时钟极性表示时钟信号在空闲时的电平;时钟相位决定数据是在 SCK的上升沿采样还是下降沿采样。根据时钟极性和时钟相位的不同组合,可以得到 SPI 总线的4 种工作模式,如图所示:SPI四种传输模式(1)SPI0 模式下的 CPOL 为 0,SCK的空闲电平为低;CPHA 为 0,数据在串行同步时钟的第一个跳变沿(由于 CPOL 为低,因此第 1 个跳变沿只能为上升沿)时数据被采样。 (2)SPI1 模式下的 CPOL 也为 0,SCK的空闲电平为低;但是 CPHA 为 1,数据在串行同步时钟的第二个跳变沿(由于 CPOL 为低,因此第 2 个跳变沿只能为下降沿)时数据被采样。 (3)SPI2 模式下的 CPOL 为 1,SCK的空闲电平为高;CPHA 为 0,数据在串行同步时钟的第1个跳变沿(由于 CPOL 为高,因此第 1 个跳变沿只能为下降沿)时数据被采样。 (4)SPI3 模式下的 CPOL 为 1,SCK的空闲电平为高;CPHA 为 1,数据在串行同步时钟的第 2 个跳变沿(由于 CPOL 为高,因此第 1 个跳变沿只能为上升沿)时数据被采样。 在上述 4 种模式中,使用的最为广泛的是 SPI0 和 SPI3 方式。由于每一种模式都与其他三种不兼容,因此为了完成主、从设备间的通讯,主、从设备的 CPOL 和 CPHA 必须有相同的设置。读者需要注意的是:如果主设备/从设备在 SCK上升沿发送数据,则从设备/主设备最好在下降沿采样数据;如果主设备/从设备在SCK下降沿发送数据,则从设备/主设备最好在 SCK上升沿采样数据。四、SPI协议SPI接口是一种事实标准,并没有标准协议,大部分厂家都是参照Motorola的SPI接口定义来设计的,但正因为没有确切的版本协议,不同厂家产品的SPI接口在技术上存在一定的差别,容易引起歧义,有的甚至无法互联(需要用软件进行必要的额修改)。本次设计基于一种使用较为普遍的协议来进行设计,通过简单协议来理解并设计SPI接口功能。SPI 协议是一个环形总线结构,其时序其实比较简单,主要是在时钟脉冲 SCK 的控制下,两个双向移位寄存器 SPI数据寄存器数据 进行数据交换。我们假设主机的 8 位寄存器 SPIDATA1 内的数据是10101010,而从机的 8 位寄存器 SPIDATA2 内的数据是 01010101,在上升沿的时候发送数据,在下降沿的时候接收数据,最高位的数据先发送,主机和从机之间全双工通信,也就是说两个 SPI接口同时发送和接收数据,如图所示。从图中我们也可以看到,SPIDATA 移位寄存器总是将最高位的数据移出,接着将剩余的数据分别左移一位,然后将接收到得数据移入其最低位。CSMISOMOSISCLKCS1010101001010101MSBSPIDATA1LSBMSBLSBSPIDATA2如图所示,当第一个上升沿来的时候,SPIDATA1 将最高位 1 移除,并将所有数据左移1位, 这时 MOSI 线为高电平,而 SPIDATA2 将最高位 0 移出, 并将所有数据左移 1 位, 这样 MISO线为低电平。然后当下降沿到来的时候,SPIDATA1 将锁存 MISO 线上的电平,并将其移入其最低位,同样的,SPIDATA2 将锁存 MOSI 线上的电平,并将其移入最低位。经过 8 个脉冲后,两个移位寄存器就实现了数据的交换,也就是完成了一次 SPI 的时序。1010101010101010101010101010101010101010101010100011第一个上升沿第一个下降沿五、仿真实现SPI时序图如下图所示:下图是基于Xilinx的Spartan-3E平台采用Verilog语言编译仿真后的SPI接口时序图:附录Verilog源代码如下所示:timescale 1ns / 1ps/ Company: / Engineer: / / Create Date: 00:34:32 04/09/2013 / Design Name: / Module Name: spi / Project Name: / Target Devices: / Tool versions: / Description: / Dependencies: / Revision: / Revision 0.01 - File Created/ Additional Comments: /module spi(rst,clk,rd,wr,datain,spics,spiclk,spido,spidi,dataout);input rst;/置位信号,低有效inputclk;/时钟信号inputrd;/接收数据命令inputwr;/发送数据命令inputspidi;/spi数据输入信号input7:0 datain;/发送数据输入output spics;/spi片选信号output spiclk;/spi时钟信号output spido; /spi数据输出信号output 7:0 dataout;/接收数据输出regspics;regspiclk;regspido;reg7:0 dataout,dstate,dsend,dreceive;/cntreg1:0spistate;parameter idle = 2b00;parameter send_data = 2b01;parameter receive_data = 2b10;initialbeginspics= 1b1;spiclk= 1b1;spido= 1b1;endalways(posedge clk)beginif(!rst)beginspistate = idle;spics= 1b1;spiclk= 1b1;spido= 1b1;dstate= 8d0;endelsebegincase(spistate)2b00:beginif(wr=1b0)&(rd=1b1) /发送数据转换beginspistate= send_data;dstate= 8d0;dsend= datain;end else if(wr=1b1)&(rd=1b0) /接收数据转换beginspistate= receive_data;dstate= 8d0;endelsebeginspistate= idle;dstate=8d0;endend2b01:/发送数据状态begincase(dstate)8d0:/产生片选信号beginspics= 1b0;spiclk= 1b1;spido= 1b1;dstate= 8d1;end8d1:beginspics= 1b0;spiclk= 1b1;spido= 1b1;dstate= 8d2;end8d2:beginspics= 1b0;spiclk= 1b0;spido= 1b1;dstate= 8d3;end8d3:beginspics= 1b0;spiclk= 1b1;spido= dsend7; /发送数据最高位dstate= 8d4;end8d4:beginspics= 1b0;spiclk= 1b0;spido= dsend7;dstate= 8d5;end8d5:beginspics= 1b0;spiclk= 1b1;spido= dsend6; dstate= 8d6;end8d6:beginspics= 1b0;spiclk= 1b0;spido= dsend6; dstate= 8d7;end8d7:beginspics= 1b0;spiclk= 1b1;spido= dsend5; dstate= 8d8;end8d8:beginspics= 1b0;spiclk= 1b0;spido= dsend5; dstate= 8d9;end8d9:beginspics= 1b0;spiclk= 1b1;spido= dsend4; dstate= 8d10;end8d10:beginspics= 1b0;spiclk= 1b0;spido= dsend4; dstate= 8d11;end8d11:beginspics= 1b0;spiclk= 1b1;spido= dsend3; dstate= 8d12;end8d12:beginspics= 1b0;spiclk= 1b0;spido= dsend3; dstate= 8d13;end8d13:beginspics= 1b0;spiclk= 1b1;spido= dsend2; dstate= 8d14;end8d14:beginspics= 1b0;spiclk= 1b0;spido= dsend2; dstate= 8d15;end8d15:beginspics= 1b0;spiclk= 1b1;spido= dsend1; dstate= 8d16;end8d16:beginspics= 1b0;spiclk= 1b0;spido= dsend1; dstate= 8d17;end8d17:beginspics= 1b0;spiclk= 1b1;spido= dsend0; dstate= 8d18;end8d18:beginspics= 1b0;spiclk= 1b0;spido= dsend0; dstate= 8d19;end8d19:beginspics= 1b1;spiclk= 1b1;spido= 1b1; dstate= 8d20;end8d20:beginspics= 1b1;spiclk= 1b1;spido= 1b1; dstate= 8d0;spistate = idle;enddefault:beginspics= 1b1;spiclk= 1b1;spido= 1b1; spistate = idle;endendcaseend2b10:/接收数据状态begincase(dstate)/片选信号有效8d0:beginspics= 1b0;spiclk= 1b1;spido= 1b1;dstate= 8d1;end8d1:beginspics= 1b0;spiclk= 1b1;spido= 1b1;dstate= 8d2;end8d2:beginspics= 1b0;spiclk= 1b0;spido= 1b1;dstate= 8d3;end8d3:beginspics= 1b0;spiclk= 1b1;dstate= 8d4;end8d4:beginspics= 1b0;spiclk= 1b0;/下降沿数据读取dreceive7 =spidi;/接收数据最高位dstate= 8d5;end8d5:beginspics= 1b0;spiclk= 1b1;dstate= 8d6;end8d6:beginspics= 1b0;spiclk= 1b0;dreceive6 =spidi;dstate= 8d7;end8d7:beginspics= 1b0;spiclk= 1b1;dstate= 8d8;end8d8:beginspics= 1b0;spiclk= 1b0;dreceive5 =spidi;dstate= 8d9;end8d9:beginspics= 1b0;spiclk= 1b1;dstate= 8d10;end8d10:beginspics= 1b0;spiclk= 1b0;dreceive4 =spidi;dstate= 8d11;end8d11:beginspics= 1b0;spiclk= 1b1;dstate= 8d12;end8d12:beginspics= 1b0;spiclk= 1b0;dreceive3 =spidi;dstate= 8d13;end8d13:beginspics= 1b0;spiclk= 1b1;dstate= 8d14;end8d14:beginspics= 1b0;spiclk= 1b0;dreceive2 =spidi;dstate= 8d15;end8d15:beginspics= 1b0;spiclk= 1b1;dstate= 8d16;end8d16:beginspics= 1b0;spiclk= 1b0;dreceive1 =spidi;dstate= 8d17;end8d17:beginspics= 1b0;spiclk= 1b1;dstate= 8d18;end8d18:beginspics= 1b0;spiclk= 1b0;dreceive0 =spidi;dstate= 8d19;end8d19:beginspics= 1b0;spiclk= 1b0;spido= 1b1;dstate= 8d20;dataout=dreceive;end8d20:beginspics= 1b1;/片选信号无效spiclk= 1b1;spido= 1b1;dstate= 8d0;spistate =idle;endendcaseenddefault:beginspics= 1b1;spiclk= 1b1;spido= 1b1;spistate = idle;endendcaseendendendmoduletimescale 1ns / 1psVerilog Module测试模块:/ Company: / Engineer:/ Create Date: 16:27:15 04/10/2013/ Design Name: spi/ Module Name: E:/fpga/spi_reg/spi_instance.v/ Project Name: spi_reg/ Target Device: / Tool versions: / Description: / Verilog Test Fixture created by ISE for module: spi/ Dependencies:/ / Revision:/ Revision 0.01 - File Created/ Additional Comments:/ /module spi_instance;/ Inputsreg rst;reg clk;reg rd;reg wr;reg 7:0 datain;reg spidi;/ Outputswire spics;wire spiclk;wire spido;wire 7:0 dataout;/ Instantiate the Unit Under Test (UUT)spi uut (.rst(rst), .clk(clk), .rd(rd), .wr(wr), .datain(datain), .spics(spics), .spiclk(spiclk), .spido(spido), .spidi(spidi), .dataout(dataout)/.dataout(datain);parameter PERIOD = 20;initial begin/ Initialize Inputsrst = 0;clk = 0;rd = 0;wr = 0;datain = 0;spidi = 0;/ Wait 100 ns for global reset to finish#100;/ Add stimulus hereendinitial begin/时钟信号的产生forever #(PERIOD/2) clk = clk;endinitial begin/复位信号的撤销rst=1;endinitial begin/写数据/forever/wr=0;rd=1;/foreverdatain=8b10101010;end endmodule袁节膅薂羄肅蒃薁蚃芀荿薀螆肃芅蕿袈芈膁蚈羀肁蒀蚇蚀袄莆蚇螂肀莂蚆羅袂芈蚅蚄膈膄蚄螇羁蒂蚃衿膆莈蚂羁罿芄螁蚁膄膀螁螃羇葿螀袅膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃蚂肂莈蒂螄芈芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羁莀蒈羃膇芆蒇蚃羀膂蒆螅膅蒁薅袇羈莇薄罿膄芃薃虿羆艿薃袁节膅薂羄肅蒃薁蚃芀荿薀螆肃芅蕿袈芈膁蚈羀肁蒀蚇蚀袄莆蚇螂肀莂蚆羅袂芈蚅蚄膈膄蚄螇羁蒂蚃衿膆莈蚂羁罿芄螁蚁膄膀螁螃羇葿螀袅膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃蚂肂莈蒂螄芈芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羁莀蒈羃膇芆蒇蚃羀膂蒆螅膅蒁薅袇羈莇袄芈蒇袇螀芇蕿蚀聿芆艿蒃肅芅蒁螈羁芄薃薁袆芃芃螆螂芃莅蕿肁节蒈螅羇莁薀薈袃莀艿螃蝿荿莂薆膈莈薄袁肄莇蚆蚄羀莇莆袀袆羃蒈蚂螂羂薁袈肀肁芀蚁羆肁莃袆袂肀薅虿袈聿蚇蒂膇肈莇螇肃肇葿薀罿肆薂螆袅肅芁薈螁膅莃螄聿膄蒆薇羅膃蚈螂羁膂莈蚅袇膁蒀袀螃膀薂蚃肂腿节衿羈腿莄蚂袄芈蒇袇螀芇蕿蚀聿芆艿蒃肅芅蒁螈羁芄薃薁袆芃芃螆螂芃莅蕿肁节蒈螅羇莁薀薈袃莀艿螃蝿荿莂薆膈莈薄袁肄莇蚆蚄羀莇莆袀袆羃蒈蚂螂羂薁袈肀肁芀蚁羆肁莃袆袂肀薅虿袈聿蚇蒂膇肈莇螇肃肇葿薀罿肆薂螆袅肅芁薈螁膅莃螄聿膄蒆薇羅膃蚈螂羁膂莈蚅袇膁蒀袀螃膀薂蚃肂腿节衿羈腿莄蚂袄芈蒇袇螀芇蕿蚀聿芆艿蒃肅芅蒁螈羁芄薃薁袆芃芃螆螂芃莅蕿肁节蒈螅羇莁薀薈袃莀艿螃蝿荿莂薆膈莈薄袁肄莇蚆蚄羀莇莆袀袆羃蒈蚂螂羂薁袈肀肁芀蚁羆肁莃袆袂肀薅虿袈聿蚇蒂膇肈莇螇肃肇葿薀罿肆薂螆袅肅芁薈螁膅莃螄聿膄蒆薇羅膃蚈螂羁膂莈蚅袇膁蒀袀螃膀薂蚃肂腿节衿羈腿莄蚂袄芈蒇袇螀芇蕿蚀聿芆艿蒃肅芅蒁螈羁芄薃薁袆芃芃螆螂芃莅蕿肁节蒈螅羇莁薀薈袃莀艿螃蝿荿莂薆膈莈薄袁肄莇蚆蚄羀莇莆袀袆羃蒈蚂螂羂薁袈肀肁芀蚁羆肁莃袆袂肀薅虿袈聿蚇蒂膇肈莇螇肃肇葿薀罿肆薂螆袅肅芁薈螁膅莃螄聿膄蒆薇羅膃蚈螂羁膂莈蚅袇膁蒀袀螃膀薂蚃肂腿节衿羈腿莄蚂袄芈蒇袇螀芇蕿蚀聿芆艿蒃肅芅蒁螈羁芄薃薁袆芃芃螆螂芃莅蕿肁节蒈螅羇莁薀薈袃莀艿螃蝿荿莂薆膈莈薄袁肄莇蚆蚄羀莇莆袀袆羃蒈蚂螂羂薁袈肀肁芀蚁羆肁莃袆袂肀薅虿袈聿蚇蒂膇肈莇螇肃肇葿薀罿肆薂螆袅肅芁薈螁膅莃螄聿膄蒆薇羅膃蚈螂羁膂莈蚅袇膁蒀袀螃膀薂蚃肂腿节衿羈腿莄蚂袄芈蒇袇螀芇蕿蚀聿芆艿蒃肅芅蒁螈羁芄薃薁袆芃芃螆螂芃莅蕿肁节蒈螅羇莁薀薈袃莀艿螃蝿荿莂薆膈莈薄袁肄莇蚆蚄羀莇莆袀袆羃蒈蚂螂羂薁袈肀肁芀蚁羆肁莃袆袂肀薅虿袈聿蚇蒂膇肈莇螇肃肇葿薀罿肆薂螆袅肅芁薈螁膅莃螄聿膄蒆薇袁节膅薂羄肅蒃薁蚃芀荿薀螆肃芅蕿袈芈膁蚈羀肁蒀蚇蚀袄莆蚇螂肀莂蚆羅袂芈蚅蚄膈膄蚄螇羁蒂蚃衿膆莈蚂羁罿芄螁蚁膄膀螁螃羇葿螀袅膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃蚂肂莈蒂螄芈芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羁莀蒈羃膇芆蒇蚃羀膂蒆螅膅蒁薅袇羈莇薄罿膄芃薃虿羆艿薃袁节膅薂羄肅蒃薁蚃芀荿薀螆肃芅蕿袈芈膁蚈羀肁蒀蚇蚀袄莆蚇螂肀莂蚆羅袂芈蚅蚄膈膄蚄螇羁蒂蚃衿膆莈蚂羁罿芄螁蚁膄膀螁螃羇葿螀袅膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃蚂肂莈蒂螄芈芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羁莀蒈羃膇芆蒇蚃羀膂蒆螅膅蒁薅袇羈莇薄罿膄芃薃虿羆艿薃袁节膅薂羄肅蒃薁蚃芀荿薀螆肃芅蕿袈芈膁蚈羀肁蒀蚇蚀袄莆蚇螂肀莂蚆羅袂芈蚅蚄膈膄蚄螇羁蒂蚃衿膆莈蚂羁罿芄螁蚁膄膀螁螃羇葿螀袅膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃蚂肂莈蒂螄芈芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羁莀蒈羃膇芆蒇蚃羀膂蒆螅膅蒁薅袇羈莇薄罿膄芃薃虿羆艿薃袁节膅薂羄肅蒃薁蚃芀荿薀螆肃芅蕿袈芈膁蚈羀肁蒀蚇蚀袄莆蚇螂肀莂蚆羅袂芈蚅蚄膈膄蚄螇羁蒂蚃衿膆莈蚂羁罿芄螁蚁膄膀螁螃羇葿螀袅膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃蚂肂莈蒂螄芈芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羁莀蒈羃膇芆蒇蚃羀膂蒆螅膅蒁薅袇羈莇薄罿膄芃薃虿羆艿薃袁节膅薂羄肅蒃薁蚃芀荿薀螆肃芅蕿袈芈膁蚈羀肁蒀蚇蚀袄莆蚇螂肀莂蚆羅袂芈蚅蚄膈膄蚄螇羁蒂蚃衿膆莈蚂羁罿芄螁蚁膄膀螁螃羇葿螀袅膃蒅蝿
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 农业科技推广与应用合作框架协议
- 2025年马鞍山市科学技术协会所属事业单位公开选调工作人员2名考试模拟试题及答案解析
- 2025年济南市钢城区城镇公益性岗位安置(65个)考试参考题库及答案解析
- 农业项目合作与资金扶持协议
- 贷款外包协议合同(标准版)
- 保险中介资本托管协议范文
- 个人客户信用卡支付协议
- 2025年果皮箱行业研究报告及未来行业发展趋势预测
- 多方合作框架协议书模板
- 写字楼设施改造协议
- 纺织企业安全生产知识培训
- 小区物业合伙管理协议书
- 2025年全国小学生“学宪法、讲宪法”活动知识竞赛题库及答案
- 小学心理健康教育四级预警汇报流程
- 教案2025秋形势与政策纪念抗战胜利坚定民族信念抗战胜利80周年
- 2025年学法减分试题及答案
- 《智能建造概论》高职完整全套教学课件
- 2025年中小学教师师德师风考试题库及答案
- 2025年商业店铺出租合同(标准版)(可修改可打印)
- 设备采购质保金管理制度
- 互助友爱班级大家庭主题班会课件
评论
0/150
提交评论