140 likes | 291 Views
Technion – Israel Institute of Technology Department of Electrical Engineering High Speed Digital Systems Lab. Controllers-system for APS – CubeSat nano-satellite. Instructor: Daniel Alkalay Students: Moshe Emmer & Meir Harar. שעון אטומי. A ccurate P ositioning S ystem. Magneto-meter.
E N D
Technion – Israel Institute of Technology Department of Electrical Engineering High Speed Digital Systems Lab Controllers-system for APS – CubeSatnano-satellite Instructor: Daniel Alkalay Students: Moshe Emmer & Meir Harar
שעון אטומי Accurate Positioning System Magneto-meter מד שמש Rate Gyro APS & TLM TransCeiver מגנטו-טורקרים Engines Power APS Cubesat Bus Architecture Control Payload Power Distribution Over-current control Telemetry Battery SA I/F & Bat C/D- Control TLM TLM On-Board Controllers uBlaze + pBlaze + State-Machines TLM TT+C Attitude System Sensors & actuators S & A I / F Sensors Attitude Control Actuators
From characterization presentation… • Intro to xilinx FPGA technology and development system (E.D.K/ I.S.E) • Create mini project, which includes several cores, peripherals and different communication modules. • AR: Redefining mini project – to serve main project’s interests: • Mini Project goals: Create a design, using MicroBlaze soft processor, which will implement a communication protocol between system and external device (Hyper terminal on PC, for instance). Designing will be divided into two aspects: • Hardware – building system architecture using available busses, peripherals IP’s etc’ • Software – implementing a small program, written in C, and translate it into MicroBlaze target using EDK (learning and searching existed functions)
Progress so far…. • Introduction to the Cube-Sat system, understanding control system architecture • Learning Xilinx FPGA architecture • Diving inside Lab tools level – Using the “Spartan III” starter board, experiencing in VHDL-only design (no MB) and E.D.K. • Since no pre requisites (micro processors) – Time was dedicated to understand microprocessor logic concepts in general and MicroBlaze architecture in particular. (elaborated straight ahead…) • Implemented a logic only system using VHDL (No MicroBlaze) • Starting to implement a simple controller using MicroBlaze core, buses and few periphrials
What’s next ? • Mini Project implementation – continue and finish • Enlarge our tool box - apart MicroBlaze, study PicoBlaze and F.S.M notions and practice • Study how to coordinate few processors • After receiving preliminary algorithms input from AE students – implementing them using all three tools (MicroBlaz, PicoBlaze and FSM)
MicroBlaze – Soft processor for FPGA MicroBlaze Core Block Diagram
Highly configurable, includes the following: • • Thirty-two 32-bit general purpose registers • • 32-bit instruction word with three operands and two addressing modes • • 32-bit address bus • • Single issue pipeline, divided into three stages: • Fetch • Decode • Execute MicroBlaze Features
Registers 32 general purpose registers (R0-R31) Five special purpose registers: PC (Program Counter) The 32-bit address of the execution instruction MSR (Machine Status Register) Contains control and status bits for the processor EAR (Exception Address register) Stores the full load/store address that caused the exception ESR (Exception Status Register) Contains status bits for the processor FSR (Floating-point Status Register) Contains status bits for the floating-point unit
Memory Architecture Harvard memory architecture Each address space has a 32-bit range (up to 4GByte of instructions / data memory) The instruction and data memory ranges can be mapped to the same physical memory Data accesses must be aligned (word access on word boundaries, halfword on halfword boundaries) Instruction accesses must be word aligned
Busses - LMB LMB (Local Memory Bus) Synchronous, used primarily to access on-chip block RAM Simple protocol, ensures that local block RAM are accessed in a single clock cycle
Busses – OPB OPB (On-chip Peripheral Bus) General purpose synchronous bus, designed for easy connection of on-chip peripheral devices 32-bit data bus, dynamic bus sizing (byte, halfword or word) Support for multiple OPB bus masters Features (for example): General Purpose IO Timer / Counter Block Watchdog Timer / Timebase Interrupt Controller OPB arbiter JTAG UART (for debugging purposes)
General Purpose IO Simple peripheral, consisting of two registers and a multiplexer for reading register contents and the GPIO I/O signals The GPIO block diagram is shown here:
I-LMB Cntrl BRAM_1 D-LMB Cntrl D-LMB I-LMB OPB LEDs F.S.L Microblaze_0 Microblaze_1 UARTRS232 OPB I-LMB D-LMB I-LMB Cntrl BRAM_0 D-LMB Cntrl
Schedule • Week 12 : • Learn how the MicroBlaze communicates with an off-board peripheral (e.g. HyperTerminal) through the OPB. • Week 13-14: • Build the MiniProject – A microcontroller which implements a simple calculator using GPIO and HyperTerminal.