嵌入式系统第一讲研嵌入式系统介绍课件_第1页
嵌入式系统第一讲研嵌入式系统介绍课件_第2页
嵌入式系统第一讲研嵌入式系统介绍课件_第3页
嵌入式系统第一讲研嵌入式系统介绍课件_第4页
嵌入式系统第一讲研嵌入式系统介绍课件_第5页
已阅读5页,还剩113页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第一讲嵌入式系统介绍Email:本讲主要内容嵌入式系统概述实验室介绍与课程说明嵌入式系统概要介绍EELiod270开发系统介绍Module板、EDR板Banyan-UE仿真器ARM处理器简介体系结构、编程模型、ARM指令系统嵌入式系统概述应用于消费电子产品嵌入式Internet应用嵌入式系统的定义(一)IEEE对嵌入式系统的定义:

Embeddedsystemisakindofdeviceusedtocontrol,monitororassisttheoperationofequipment,machineryorplant.

“控制、监视或者辅助设备、机器和车间运行的装置”嵌入式系统的特点系统内核小:一般应用于小型电子装置。专用性强:软硬件结合紧密,针对硬件进行系统的移植。系统精简:系统软件和应用软件紧密融合,部分无明显区别。实时多任务的操作系统:合理调度多任务,RTOS开发平台。专门的开发工具和环境。实验室条件深圳亿道公司EELiod270教学开发平台IntelXscale270微处理器,520MHz完善的硬件平台支持WinCE和Linux操作系统课程主要内容ARM与EEliod270开发系统介绍嵌入式Linux系统的构建与启动分析嵌入式Linux下程序开发课程安排(一)3-18周3-5周理论课6-18周嵌入式Linux实验系统构建驱动程序实验自选综合实验评分标准理论课:10%实验:90%内部网络资源ftp服务器:,port:21,user:emb,pwd:embeddedEELiod硬件平台资料ADS开发系统资料嵌入式Linux

BSP软件包实验指导书其他安装软件(虚拟机,Redhat9等)参考书及资料(二)AlessandroRubini,魏永明等译,linux设备驱动程序,第二版,中国电力出版社,2002中国Linux论坛嵌入式开发网嵌入式系统的基本构成存储器及外围电路嵌入式处理器嵌入式操作系统应用软件嵌入式硬件系统嵌入式处理器各种类型存储器模拟电路及电源接口控制器及接插件嵌入式软件系统板级支持包(BSP)操作系统(OS/RTOS)设备驱动(DeviceDriver)协议栈(ProtocolStack)应用程序(Application)嵌入式处理器的分类嵌入式微处理器(MPU)ARMDragonballMc9328Mx1Xscale270嵌入式微控制器(MCU)8051、P51XA、MC68HC05/11/12/16、68300等嵌入式DSP处理器嵌入式片上系统(SOC-SystemOnChip)嵌入式可编程片上系统(EPSOC)ARMARM的产品ARM处理器内核,以知识产权(IP)形式提供给IC生产厂家硬核:有和特定工艺相连系的物理版图。软核:用硬件描述语言或C语言写成,用于功能仿真ARM开发工具、SOC开发工具、评估板等ARM公司不生产芯片ARM赢利模式:专利授权费+版费目前在通信领域处于统治地位,100%的CDMA手机和85%以上的WCDMA手机IntelInside&InsideIntelARM芯片年出货量超过几十亿片ARM营收中,手机芯片占2/3ARM嵌入式微处理器嵌入式操作系统特点除具有普通操作系统的功能如任务调度、中断处理等外,嵌入式操作系统还有以下特点:编码体积小,适合有限的存储空间面向应用,可裁减和移植部分要求实时性强,又称实时多任务操作系统(RTOS)可靠性高以及较强的网络功能嵌入式操作系统通常按体系的分类Windows兼容系列WindowsCE/NT/XPLinux类嵌入式Linux,uCLinux,RTLinuxAndroid及其派生的iPhone、oPhone、LePhone等通信领域嵌入式操作系统VxWorks,Nucleus,VRTX,QNS,pSOS其他如Symbian、BlackBerry等嵌入式操作系统结构嵌入式系统的应用开发本实验室条件支持:无OSADS集成开发环境有OS嵌入式LinuxWindowsCE嵌入式产品开发过程集成开发环境ARMADS(ARMDeveloperSuits)它是ARM公司的集成开发环境,包括命令行开发工具、图形开发工具、实用工具和支持软件4部分,可以进行编辑、编译及调试C、C++及汇编程序。MetrowerksCodeWarriorforARMADSv1.2ARM汇编及C程序的编辑、编译AXD调试嵌入式应用开发的调试由于嵌入式系统的可用资源有限,嵌入式开发和调试工作通常要通过高性能的宿主机完成。 嵌入式应用软件通过宿主机上的交叉编译器,完成交叉编译和连接后下载到目标机。宿主机:进行嵌入式软件开发的主机目标机:将要开发的目标板嵌入式开发的调试方法大致有以下几种调试方法:模拟调试方式ROMMonitor方式(或Angel方式)ICE仿真JTAG调试与仿真模拟开发调试方式模拟开发调试不需开发板硬件,一台PC即可纯软件模拟嵌入式处理器的功能和指令。如ARM公司的ARMulator模拟器。它虽然简单可行,但是缺乏在线调试和实时仿真功能。ROMMonitor调试方式(一)ROMMonitor方式(或Angel方式)ROMMonitor(或Angel)是运行在目标机的Flash或ROM的一段程序,它主要负责监控目标机上被调试程序的运行情况。通过和宿主机的配合,完成嵌入式系统的调试。它是目前低廉有效的一种调试方式。之前课程使用Metrowerks公司的CodeWarrior进行开发调试时要用到的Metro-TRK就属于这类软件。ROMMonitor调试方式(二)ICE在线仿真模式在线仿真(InCircuitEmulator)传统硬件级仿真调试模式取下目标板MPU;在线仿真器可以完全仿真MPU的行为;通过卡座等连接到目标板。它支持单步执行、断点、反汇编、源程序级调试。优点:功能非常强大,软硬件均可做到完全实时在线调试缺点:适合于简单的MPU一般滞后MPU几个月价格昂贵宿主机目标板仿真器硬件连接示意图JTAG仿真调试方式(一)JTAG(JointTestActionGroup)联合测试行动小组,是IEEE的一个标准JTAG初始主要用于芯片内部测试,可对具有JTAG接口的芯片的硬件电路进行边界扫描和故障检测后用于调试:在芯片内部定义TAP(TestAccessPort),可以访问寄存器和挂在总线上的设备JTAG仿真调试方式(二)JTAG调试器硬件简单,只进行并口/usb和JTAG接口的电平转换主要工作由主机软件完成,如JTAG/usb协议转换等速度慢,一般10K/s级别JTAG仿真器硬件复杂,除完成JTAG/usb协议转换,可能有MPU进行控制提供并口/USB接口等,速度快价格贵JTAG仿真调试方式(三)JTAG仿真器

ARM处理器为了方便调试,内含EmbededICE宏单元,并留有JTAG调试接口,支持在线仿真。它无需目标存储器,不占用目标系统的端口。使用集成开发环境配合JTAG仿真器是目前最常用的一种调试方式。宿主机目标板仿真器硬件连接示意图JTAG仿真调试方式(四)嵌入式Linux开发调试嵌入式Linux工具链交叉编译器GCCarm-linux-gcc项目管理工具MAKE调试工具GDBbreak 设置断点Run 执行程序Step 单步跟踪进入Next 单步不进入函数Print,Display 显示变量值QuitEELiod270开发系统介绍XScale架构PXA270时钟频率分312MHz、416MHz、520MHz及624MHz四种内部集成IntelWirelessMMX技术,该技术可提供额外的性能以支持3D游戏和高级视频采用了SpeedStep低功耗技术,通过智能管理电压和频率变化实现节省高达55%的功耗集成了快速捕捉(IntelQuickCapture)技术,使镜头支持400万以上像素XScale特点采用ARMV5TE指令集无线MMX指令单元IMMU和DMMUI-Cache和D-Cache写缓冲器(8入口的高速FIFO)协处理器电源管理与性能监控调试单元XScale协处理器CP0:用于DSP处理,更好的处理多媒体信息,包含一个40位累加器,并增加了8条新的指令。CP1:用于无线MMX指令数据传输和状态控制等CP6:为PXA27X新增的协处理器,主要用于减少访问中断控制寄存器的时间。CP14:用于系统的性能监视、时钟管理、电源管理和软件调试CP15:用于MMU控制PXA270XSBase270开发平台触摸屏8”TFTLCD640*480JTAG接口120pin扩展接口PXA270520MHz32PinLCD接口数码管*4CF卡喇叭SD/MMC卡SIMCardCamera全功能串口RTCBattery红外收发器RS485红外串口CanBus以太网口USBHost音频输入输出USBSlave4*4矩阵键盘高亮度LED*8GPS模块接口步进电机BT串口功能转换开关直流电机Flash*32MSdram*64M平台硬件分层分EDR板(底板)和Module板(模块板或核心板)Module板 ——最小系统EDR板 ——功能接口板Module板包含以下部分MPU ——IntelXscalePXA270520MHzSDRAM ——双片,64M,缺省地址空间是0xa0000000–0xafffffff

FLASH ——双片,32M,其缺省地址空间是0x00000000–0x03ffffff

CPLD ——采用Xilinx公司的XC2C128可编程器件,丰富片选及加密串口 ——全功能调试串口网络接口JTAG电源控制——LP3971芯片,IntelSpeedStep动态电源管理技术Module板另外还含有以下接口电路音频控制接口电路——PhilipsUCB1400芯片,内含10bits的ADCLCD控制电路触摸屏控制电路通过两个120pin的连接器连接到EDR板Module板EDR板PCMCIA/CF卡接口MMC/SD卡接口RTC——实时时钟数码管和LED按键Sw1-sw4直入键盘Sw5-sw16矩阵扫描QuickCapture摄像头模块——支持400万像素数码镜头,并能提供最大416Mbps的数据传输速率EDR板RS232BT_UART(蓝牙串口)——只有收发信号线IR_UART(红外串口)——RS485GPS模块接口——需另外的GPS模块板CAN总线接口——汽车应用,使用270的SPI(串行外设接口)直流电机——接口信号电压为+3.3v和-3.3v时,分别正向转动和反向转动EDR板步进电机——有方向端,四相步进ABCDUSB接口两个HOST接口,支持spec1.1规范一个SLAVE接口扩展插槽——CON10,CON11可外接AD/DA模块板电源外接+5V/3A,+12V/2A输出的开关电源5v及经由变换的3.3v给各逻辑电路供电12v给显示屏、步进电机、风扇供电EDR板网络接口——直接从Module板引下来拨码开关——控制功能复用选择,例如QuickCapture是和马达,按键,485共用信号线EDR板Banyan-U仿真器20pins的JTAG接口和USB接口支持ARM7/ARM9/XScale系列CPU支持USB2.0/USB1.1,自动识别核心部分使用CPLD设计使用USB接口供电JTAG接口电平由目标板决定,可以支持多种电压的CPUBanyan-U仿真器基础实验在线调试FLASH烧写Banyan-UE仿真器安装使用仿真器的安装Banyan-UE-1.8.9.exe解压FlashWrite-v0.4.7到安装目录仿真器使用执行DaemonU.exe,识别处理器(见下图)Daemon图Banyan仿真器烧写FLASH执行flashwrite-v0.4.7.exe,识别flash器件型号,DeviceID选择要烧写的镜像文件,设置好烧录地址(flash地址是0x00~0x003ffffff是PAX270处理器上电起始执行地址烧写过程:选择AUTO,选中其中的erase,program,verify三项,start!Flashwrite参见Banyan-U软件手册.pdfBanyan-U硬件手册.pdfFlashWrite使用手册.pdf目前已购买的独立功能模块蓝牙模块GPRS模块GPS模块EELiod270软件目前提供WindowsCE和Linux两种嵌入式OS的支持平台配套手册和软件实验平台使用手册(WindowsCE和Linux)上机指导书基础实验上机指导书WindowsCE上机指导书Linux上机指导书BSP光盘(WindowsCE和Linux)EELIODWinCE软件EELIODLinuxBSP软件WindowsCE实验代码WindowsCE平台搭建线程同步调试驱动程序结构进程通信数据库IO接口-LEDIO接口-电机动态链接库WindowsCE实验代码无线网络通信Ping和UDP实验设备驱动实验串口实验CAN总线实验CF和SD实验USB摄像头Linux实验代码常用命令及工具Makefile实验Bootloader内核编译文件系统制作GUI应用驱动程序结构IO驱动Linux实验代码SD卡驱动USB驱动QT移植串口通信GPRS和GSM通信WebServer移植USB摄像头嵌入式数据库ARM处理器简介ARM体系结构的发展ARM简介ARM处理器命名规则ARM7TDMI核命名规则

7 -体系结构T -Thumb代码支持(16bit指令)D -Debug硬件调试模块支持M -加强的乘法支持I -EmbeddedICELogicS-可综合的软核E-DSPJ-Jazeller,允许直接执行Java字节码ARM处理器支持的运行模式ARM处理器共支持7种运行模式,分别为:用户(usr):ARM处理器正常的程序执行状态;系统模式(sys):运行具有特权的操作系统任务;

快速中断(fiq):用于高速数据传输或通道处理;外部中断(irq):用于通用的中断处理;管理模式(svc):操作系统使用的保护模式;中止(abt):当数据或指令访问中止时进入该模式,可用于虚拟存储及存储保护;未定义(und):当未定义指令执行时进入该模式,可用于硬件协处理器的软件仿真。ARM处理器运行模式除用户模式之外的其余6种称为非用户模式,或特权模式(PrivilegedModes);而特权模式中,除系统模式之外的其余5种又称为异常模式(ExceptionModes)。用户程序运行在用户模式下,不能访问一些受操作系统保护的系统资源。应用程序也不能直接进行处理器模式的切换。当需要进行处理器模式切换时,应用程序可以产生异常处理,在异常处理过程中进行处理器处理器模式的切换。这种体系结构可以使系统控制整个系统的资源。

ARM处理器运行模式当应用程序发生异常中断时,处理器进入相应的异常模式。在每一种异常模式中都有一组寄存器,供相应的异常处理程序使用,这样就可以保证在进入异常模式时,用户模式下的寄存器(保存了程序运行状态)不被破坏。系统模式系统模式并不是通过异常过程进入的,它和用户模式具有完全一样的寄存器。但是系统模式属于特权模式,可以访问所有的系统资源,也可以直接进行处理器模式切换。它主要供操作系统任务使用。通常操作系统的任务需要访问所有的系统资源,同时该任务仍然使用用户模式的寄存组,而不是使用异常模式下相应的寄存器组,这样可以保证当异常中断发生时可以正常保存当前工作状态,进行模式切换。ARM的寄存器组织ARM处理器共有37个32位寄存器,其中31个为通用寄存器,6个状态寄存器。ARM状态下的寄存器组织未分组寄存器R0~R7分组寄存器R8~R14程序计数器R15(PC)当前程序状态寄存器(CPSR)备份的程序状态寄存器(SPSR)Thumb状态下的寄存器组织Thumb状态下的寄存器组织通用寄存器R0~R7程序计数器PC堆栈指针SP(R13)连接寄存器LRCPSR和SPSRR13(SP-堆栈指针)每种异常模式都有备份寄存器R13_usr,R13_svc,R13_abt,R13_und,R13_irq,R13_fiq用作堆栈指针每种异常模式有自己专用的栈地址R13用于被中断程序的现场保护,即保存需要保护的寄存器值R14(LR-连接寄存器)每种异常模式都有备份寄存器R14_usr,R14_svc,R14_abt,R14_und,R14_irq,R14_fiq两种作用存放当前子程序的返回地址异常中断发生时,该异常模式R14_xxx被设置为将要返回的地址R15(PC-程序计数器)指令地址PC=当前执行指令地址+8地址值字对齐及半字对齐例MOVPC,PC ;跳转到下面第二条指令状态寄存器状态寄存器:当前程序状态寄存器CPSR,可以在任何工作模式下被访问;程序状态备份寄存器SPSR,只有在异常模式下,才能被访问;CPSR-当前程序状态寄存器(一)当前程序状态寄存器CPSR

N:补码形式的有符号数运算时,1为负,0为正;Z:1表示结果为零;C:加减法的进位或借位,以及非加减法的最后移位;V:1表示补码形式的有符号数加减运算时符号位溢出;CPSR-当前程序状态寄存器(二)Q:v5以上版本才有,描述增强DSP运算指令是否发生溢出;I、F:中断禁止位,1表示中断禁止;T:指示处理器处于ARM或Thumb工作状态;CPSR-当前程序状态寄存器(三)M[4:0]:表示处理器的运行模式0b10000——User0b10001——FIQ0b10010——IRQ0b10011——Supervisor0b10111——Abort0b11011——Undefined0b11111——SystemARM控制程序执行的方式正常执行,每执行一条指令ARM指令PC+4Thumb指令PC+2跳转:B、BL、BX、BLX异常中断执行完当前指令,跳转到异常中断处理程序执行完返回到发生中断指令的下一条处要保护和恢复被中断程序的执行现场ARM处理器的异常中断(一)异常是指正常的程序执行流程发生暂时的停止或改变,例如在复位、有中断请求及指令预取中止时;

ARM处理器支持7种类型的异常。复位(RESET):当处理器的复位电平有效时,产生复位异常,程序跳转到复位异常处理程序处执行。未定义指令(UDEF):当ARM处理器或协处理器遇到不能处理的指令时,产生未定义指令异常。可使用该异常机制进行软件仿真。软件中断(SWI):该异常由执行SWI指令产生,可用于用户模式下的程序调用特权操作指令。使用该异常机制可以实现系统功能调用。ARM处理器的异常中断(二)指令预取中止(PABT):若处理器预取指令的地址不存在,或该地址不允许当前指令访问,存储器会向处理器发出中止信号,但当预取的指令被执行时,才会产生指令预取中止异常。数据中止(DABT):若处理器数据访问指令的地址不存在,或该地址不允许当前指令访问时,产生数据中止异常。IRQ(外部中断请求):当处理器的外部中断请求引脚有效,且CPSR中的I位为0时,产生IRQ异常。系统的外设可通过该异常请求中断服务。FIQ(快速中断请求):当处理器的快速中断请求引脚有效,且CPSR中的F位为0时,产生FIQ异常。ARM处理器的异常中断(三)异常类型模式正常向量地址高向量地址复位管理0x000000000xFFFF0000未定义指令未定义0x000000040xFFFF0004软件中断管理0x000000080xFFFF0008指令预取中止中止0x0000000C0xFFFF000C数据中止中止0x000000100xFFFF0010IRQIRQ0x000000180xFFFF0018FIQFIQ0x0000001C0xFFFF001CARM处理器的异常中断(四)异常优先级异常类型1(最高)复位2数据中止3FIQ4IRQ5预取中止6未定义指令,SWIARM处理器对异常的处理(一)对异常的响应:将下一条指令的地址存入相应异常类型的连接寄存器LR_mode;保存用户寄存器值到堆栈中将CPSR复制到相应异常类型的SPSR_mode中;设置CPSR的M[4:0],强制改变到相应的运行模式;禁止正常中断,如果异常类型为快速中断或复位,同时禁止快中断;强制PC从相关的异常向量地址取下一条指令执行,从而跳转到相应的异常处理程序处。ARM处理器对异常的处理(二)异常返回从堆栈中恢复用户寄存器将SPSR_mode复制回CPSR中复制LR_mode->PC未定义异常的操作过程进入异常:R14_und=产生异常的下一条指令地址SPSR_und=CPSRCPSR[4:0]=0b11011/*进入未定义运行模式*/CPSR[5]=0/*进入ARM工作状态*/CPSR[7]=1/*禁止正常中断*/如果设置了高向量模式,则PC=0xFFFF0004 否则 PC=0x00000004退出异常:MOVSPCR14恢复PC(从R14_und)和CPSR(从SPSR_und),并返回到该未定义指令的下一条指令处ARM推荐的异常退出指令异常类型R14(ARM)R14(Thumb)返回指令BLPC+4PC+2MOVPC,R14SWIPC+4PC+2MOVSPC,R14UDEFPC+4PC+2MOVSPC,R14FIQPC+4PC+4SUBSPC,R14,#4IRQPC+4PC+4SUBSPC,R14,#4PABTPC+4PC+4SUBSPC,R14,#4DABTPC+8PC+8SUBSPC,R14,#8RESET---例:SWI中断的R14例如: 0x8000

mov...... 0x8004

add...... 0x8008

SWI...... 0x800C

mov...... 0x8010

add......当程序执行SWI异常时,PC指向0x8010,在跳转到异常向量的之前,ARM会把R14调整到0x800CARM数据类型字(Word):在ARM体系结构中,字的长度为32位,而在8位/16位处理器体系结构中,字的长度一般为16位,请注意区分。半字(Half-Word):在ARM体系结构中,半字的长度为16位,与8位/16位处理器体系结构中字的长度一致。字节(Byte):在ARM体系结构和8位/16位处理器体系结构中,字节的长度均为8位。存储器组织以0x87654321为例小端方式对应于地址[A+3]=0x87,[A+2]=0x65,[A+1]=0x43,[A]=0x21大端方式对应于地址[A]=0x87,[A+1]=0x65,[A+2]=0x43,[A+3]=0x21Byte[A+3]Byte[A+2]Byte[A+1]Byte[A]Bit31bit0字对齐与半字对齐ARM状态,字地址的低两位bits[1:0]必须为0b00,半字地址的最低位bit[0]为0b0Thumb状态,字地址最地位bit[0]必须为0b0如果写入PC的指令地址非对齐ARMV3及以下,忽略R15的bits[1:0]ARMV4及以上,执行结果不可预知Thumb,忽略R15的bit[0]ARM处理器工作状态从编程的角度看,ARM处理器有2种工作状态并可自由切换:ARM状态:处理器执行32位的、字对准ARM指令;Thumb状态:处理器执行16位、半字对准的Thumb指令。ARM/Thumb状态的切换ARM处理器总是从ARM状态开始执行可用指令实现状态切换BLXLDR、LDM及POP当处理器进入异常中断处理程序时,自动切换到ARM状态如果从Thumb状态进入异常,处理完成退出后仍自动进入Thumb状态立即数一条ARM指令32位,可能含12位立即数immediate=immed_8循环右移(2*rotate_imm)合法:0xff,x0104,0xff0,0x3f0非法:0x101,0xff1,0x102(非偶数位)Qu:0x1fcARM指令系统ARM指令集包括:跳转指令数据处理指令程序状态寄存器处理指令加载/存储指令协处理器指令异常产生指令ARM指令系统跳转B,BL,BLX移位ASR,LSL,LSR,ROR,ROX存储加载LDR,STR软中断SWI指令名指令含义操作ADD相加Rd=Rn+op2SUB相减Rd=Rn-op2RSB反向相减Rd=op2-RnADC带进位加Rd=Rn+op2+CSBC带借位减Rd=Rn-op2+C-1RSC反向带借位减Rd=op2-Rn+C-1AND位与Rd=RnANDop2ORR位或Rd=RnORop2EOR位异或Rd=RnEORop2BIC位清零Rd=RnANDNOTop2MOV传送Rd=op2MVN传送非Rd=NOTop2CMP比较Rn-op2CMN负向比较Rd=op2-RnTST测试RnANDop2TEQ测试相等RnEORop2指令名指令含义操作MUL乘法Rd=Rm*RsMLA乘加Rd=Rm*Rs+RnUMULL无符号数乘法RdH:RdL=Rm*RsUMLAL无符号数乘加RdH:RdL+=Rm*RsSMULL有符号数乘RdH:RdL=Rm*RsSMLAL有符号数乘加RdH:RdL+=Rm*Rs多寄存器加载/存储指令(一)该指令完成多个通用寄存器与存储单元之间的数据传送。LDM|STM{cond}寻址方式Rn{!},通用寄存器组{^}符号的含义:寻址方式为:IA、IB、DA、DB、FD、ED、FA、EA;Rn:基址寄存器,不允许为R15(PC);!:指令执行后,刷新基址寄存器Rn“^”:当寄存器列表包含PC且为LDM指令时,同时将SPSR拷贝到CPSR,用于异常返回;当寄存器列表不包含PC,指示指令中所有的寄存器为用户模式下的寄存器LDM/STM操作语法:<LDM|STM>{<cond>}<addressing

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论