Broadcom PCI Storage Device Management System SDMS User guide

  • Hello! I am an AI chatbot trained to assist you with the Broadcom PCI Storage Device Management System SDMS User guide. I’ve already reviewed the document and can help you find the information you need or explain it in simple terms. Just ask your questions, and providing more details will help me assist you more effectively!
®
S14021.A
LSI53C040
Enclosure Services
Processor
PROGRAMMING
GUIDE
December 2000
Version 1.1
ii
This document contains proprietary information of LSI Logic Corporation. The
information contained herein is not to be used by or disclosed to third parties
without the express written permission of an officer of LSI Logic Corporation.
LSI Logic products are not intended for use in life-support appliances, devices,
or systems. Use of any LSI Logic product in such applications without written
consent of the appropriate LSI Logic officer is prohibited.
Document DB15-000100-01, Second Edition (December 2000)
This document describes the LSI Logic LSI53C040 Enclosure Services
Processor and will remain the official reference source for this product. This guide
is intended for use with the SAF-TE Firmware C1 source code release and meets
the criteria set within the LSI Logic Software Release Procedure.
To receive product literature, visit us at http://www.lsilogic.com.
LSI Logic Corporation reserves the right to make changes to any products herein
at any time without notice. LSI Logic does not assume any responsibility or
liability arising out of the application or use of any product described herein,
except as expressly agreed to in writing by LSI Logic; nor does the purchase or
use of a product from LSI Logic convey a license under any patent rights,
copyrights, trademark rights, or any other of the intellectual property rights of
LSI Logic or third parties.
Copyright © 1999–2000 by LSI Logic Corporation. All rights reserved.
TRADEMARK ACKNOWLEDGMENT
The LSI Logic logo design is a registered trademark of LSI Logic Corporation. All
other brand and product names may be trademarks of their respective
companies.
Preface iii
Preface
This programming guide assists experienced firmware developers who
wish to customize the LSI53C040 SAF-TE Firmware for specialized
enclosure management applications, or to develop firmware using the
LSI53C040 firmware architecture as a basis. It assumes a thorough
knowledge of the “C” programming language and the SAF-TE
specification, and understanding of the components and services that will
be provided in the enclosure design. For more background material that
may provide information on these subjects, refer to the Section
“References,” and Section “Related Publications,” in this document.
This guide contains general considerations for developers who are
designing or customizing firmware and includes:
describing the SCSI portion of the LSI53C040 firmware, including the
SCSI commands supported,
describing the two-wire serial portion of the LSI53C040 firmware,
describing the LSI53C040 implementation of the firmware for the
binary inputs/outputs, and of the LED outputs that provide enclosure
monitoring and notification services to the host,
giving information on the LSI Logic implementation of the SAF-TE
command set, and
describing the firmware configuration utility and the data structures
that hold the specific information on the components and services in
the enclosure.
Audience
This document was prepared for firmware developers who plan on
customizing the SAF-TE firmware for enclosure management
applications.
iv Preface
Organization
This document has the following chapters and appendix:
Chapter 1, Using the Programming Guide, provides details about
the conventions used in this guide, describes the SAF-TE firmware,
and lists the features.
Chapter 2, General Design Considerations, provides design
information for firmware developers.
Chapter 3, SAF-TE Source Code, discusses the Boot Module,
Configuration Module, and SAF-TE Module that contains the safte.c
source code.
Chapter 4, SAF-TE Command Implementation,liststheSAF-TE
commands supported by the LSI53C040 chip.
Chapter 5, Configuration Data and the Configuration Utility,
provides the potential questions that may be asked while running the
configuration utility.
Appendix A, LSI53C040 Board Utilities, discusses the data transfer
types.
Related Publications
LSI53C040 Enclosure Services Processor Technical Manual,
Order Number S14042.A
LSI53C040 Enclosure Services Processor SAF-TE Firmware Users
Guide, Order Number S14004.A
References
Yeralan, Sencer and Ashutosh Ahluwalia. 1997. Programming and
Interfacing the 8051 Microcontroller.
Ayala, Kenneth J. 1997. The 8051 Microcontroller: Architecture,
Programming, & Applications. Second Edition.
Preface v
Scope of this Programming Guide
This programming guide only discusses the firmware implementation of
the SAF-TE protocol, even though the LSI53C040 device could support
the SES protocol. LSI Logic will not be pursuing a SES firmware
implementation.
Conventions Used in This Manual
Hexadecimal numbers are indicated by the prefix 0x” —for example,
0x32CF. Binary numbers are indicated by the prefix “0b” —for example,
0b0011.0010.1100.1111.
This manual makes frequent references to the source code of the
LSI53C040 SAF-TE firmware. We use routine names, typed in bold,
italics, and regular text, to indicate the specific section of code being
referenced.
Revision Record
Revision Date Remarks
1.0 5/99 First Edition.
1.1 12/00 Product names changed from SYM to LSI.
vi Preface
Contents vii
Contents
Chapter 1 Using the Programming Guide
1.1 Introduction 1-1
1.2 General Description 1-2
1.3 Features 1-2
1.3.1 MPIO/MPLED Mapping 1-2
1.3.2 TWS Interface Peripheral Support 1-2
1.3.3 SAF-TE Interface 1-3
1.3.4 Programmable Enclosure Configuration Monitoring 1-4
Chapter 2 General Design Considerations
2.1 8051/8032 Background 2-1
2.1.1 8032 Architecture Features 2-2
2.1.2 Archimedes Compiler Features 2-4
2.2 The LSI53C040 Firmware 2-7
2.3 SCSI and DMA 2-8
2.4 8032-Based Timer 2-9
2.5 TWS Bus 2-9
2.6 Power-On/Start-up 2-10
2.7 Normal Processing 2-10
2.8 Interrupts 2-11
2.8.1 8032 Processor Interrupts 2-11
2.8.2 LSI53C040 Interrupts 2-12
2.9 Debugging 2-12
2.10 Setting Up A Development Environment 2-12
2.10.1 Development Tools 2-13
2.10.2 Source Code Composition 2-14
2.10.3 Register Naming Translations 2-14
2.10.4 Calling Trees 2-20
2.11 Configuration Examples 2-25
viii Contents
2.11.1 Example 1 2-25
2.11.2 Example 2 2-28
2.11.3 Example 3 2-29
Chapter 3 SAF-TE Source Code
3.1 SAF-TE Source Code Overview 3-1
3.2 Boot Module 3-2
3.3 Configuration Module 3-3
3.3.1 Loader_Options Data Structure 3-4
3.3.2 Config Data Structure 3-5
3.4 SAF-TE Module 3-19
3.4.1 Compilation Instructions for safte.c 3-19
3.4.2 Main Program 3-22
3.4.3 Interrupts 3-39
3.4.4 Error Reporting 3-49
3.5 Frequently Asked Questions (FAQ) 3-49
Chapter 4 SAF-TE Command Implementation
4.1 SCSI Commands 4-1
4.1.1 Inquiry 4-1
4.1.2 Read Buffer 4-3
4.1.3 Request Sense 4-4
4.1.4 Send Diagnostic 4-4
4.1.5 Test Unit Ready 4-5
4.1.6 Write Buffer 4-5
4.2 SAF-TE Read Buffer Commands 4-7
4.2.1 Read Enclosure Configuration (0x00) 4-7
4.2.2 Read Enclosure Status (0x01) 4-9
4.2.3 Read Device Slot Status (0x04) 4-14
4.2.4 Read Global Flags (0x05) 4-16
4.3 SAF-TE Write Buffer Commands 4-18
4.3.1 Write Device Slot Status (0x10) 4-18
4.3.2 Perform Slot Operation (0x12) 4-20
4.3.3 Send Global Flags Command (0x15) 4-22
4.4 Unsupported SAF-TE Commands 4-25
Contents ix
Chapter 5 Configuration Data and the Configuration Utility
5.1 Using the Configuration Utility 5-1
5.1.1 Myinput.txt File 5-4
5.2 Questions in the Configuration Utility 5-5
5.3 After Running the Configuration Utility 5-21
Appendix A LSI53C040 Board Utilities
A.1 Data Transfers A-1
A.1.1 Serial Port A-1
A.1.2 ISA A-2
A.1.3 SCSI A-3
A.1.4 8067 Utilities A-6
A.1.5 LSI53C040 Board Layout/Jumper Settings A-6
Index
Customer Feedback
Figures
2.1 Internal RAM 2-3
2.2 LSI53C040 Memory Map 2-4
2.3 System Configuration 2-26
2.4 Optional Drive Slot Power Configuration 2-28
2.5 Dual Fans and Power Supplies Configuration 2-30
3.1 Main Program 3-23
3.2 Flow Diagram of ir_external1() 3-43
3.3 Flow Diagram of Command_and_Data_Phases() 3-44
Tables
2.1 Source Code Files 2-14
2.2 Special Function Register Names 2-15
2.3 SCSI Core/SFF-8067 Registers 2-16
2.4 TWS Registers 2-17
2.5 Miscellaneous Registers 2-17
2.6 System Registers 2-18
xContents
2.7 MPLED/MPIO Pin Usage for Example 1 2-26
2.8 MPLED/MPIO Pin Usage for Example 2 2-29
2.9 MPLED/MPIO Pin Usage for Example 3 2-30
3.1 Source file - bootload.c - Switches 3-3
3.2 Instructions Per Device 3-13
3.3 Mapping of devices to MPIO and MPLED Banks 3-14
3.4 Switch Name and Action 3-20
3.5 Accumulator Settings 3-29
3.6 TWS High-Level Subroutines 3-30
3.7 SAF-TE Mappings 3-31
3.8 TWS Low-level Subroutines 3-32
3.9 Subroutine background_code_lode 3-34
3.10 Subroutine do_code_load 3-34
3.11 background_code_load operation 3-35
3.12 Upper Byte Choices 3-36
3.13 Interrupts Processed by 80C32 Microcontroller 3-39
3.14 Interrupt Service Routines - General 3-46
3.15 Interrupt Service Routines - SCSI Commands 3-47
3.16 Interrupt Service Routines - SCSI Read 3-48
3.17 Interrupt Service Routines - SCSI Write 3-48
3.18 Source Code Issues 3-49
4.1 Inquiry Command Response Data 4-2
4.2 Read Buffer Data Format 4-3
4.3 Sense Key Information 4-4
4.4 Write Buffer Data Format 4-5
4.5 Write Buffer Data Format (Updating SAF-TE Firmware) 4-6
4.6 Read Enclosure Configuration Return Values 4-7
4.7 Read Enclosure Status Return Values 4-10
4.8 Fan Status Return Values 4-11
4.9 Power Supply Status Return Values 4-12
4.10 Door Lock Status Return Values 4-13
4.11 Speaker Status Return Values 4-13
4.12 Read Device Slot Status Command Return Values 4-15
4.13 Power-On/Reset Default Slot Status 4-16
4.14 Read Global Flag Bytes 4-17
4.15 Write Device Slot Status Flag Bytes 4-18
4.16 Default LED Settings for Write Device Slot Status Flags 4-19
4.17 Perform Slot Operation Flags 4-20
Contents xi
4.18 Send Global Flag Bytes 4-22
4.19 Global Failure/Global Warning LED Options 4-23
4.20 Drive Failure/Drive Warning LED Options 4-24
4.21 Array Failure/Array Warning LED Options 4-24
5.1 Configuration Utility Files 5-2
5.2 General Questions 5-5
5.3 Enclosure Components Questions 5-7
5.4 Pin Assignment Questions 5-9
5.5 Default LED Settings for Write Device Slot Status Flags 5-12
5.6 Selections for Custom LED Settings for Write Device Slot
Status Flags 5-13
5.7 Device Slot Operation Questions 5-14
5.8 Status Signal Questions 5-15
5.9 TWS Bus Operation Questions 5-17
5.10 Questions for Firmware Bootloader 5-19
A.1 Capture Register Settings A-1
A.2 Command Line Inputs A-2
A.3 Configuration Using Three Serial EEPROMS A-4
A.4 Configuration Using Two Serial EEPROMS A-5
A.5 Switch Controls and Address A-7
A.6 Jumpers and Chip Address A-7
A.7 Jumper and Bus A-8
A.8 Jumpers and Branch Address A-8
A.9 Jumper and Code Load A-8
xii Contents
LSI53C040 Enclosure Services Processor Programming Guide 1-1
Chapter 1
Using the Programming
Guide
This chapter provides a general overview of the LSI53C040 Enclosure
Services Processor Firmware and includes these topics:
Section 1.1, “Introduction,” page 1-1
Section 1.2, “General Description,” page 1-2
Section 1.3, “Features,” page 1-2
1.1 Introduction
The LSI53C040 is an enclosure services processor with
28 programmable, multipurpose I/O (MPIO) pins for enclosure monitoring
and 24 programmable, multipurpose I/O pins for visual LED indicators.
The LSI53C040 firmware includes configuration data tables that allow the
user to map specific monitoring functions to each of these pins, so that
the firmware can be adapted to any enclosure environment.
The LSI53C040 uses the SAF-TE or SES protocol to detect drive
presence, condition a slot for drive insertion or removal, and monitor
enclosure services. The fan, power supply, door lock, alarm, and slot
drive power are examples of enclosure services.
1-2 Using the Programming Guide
1.2 General Description
The LSI53C040 SAF-TE firmware controls an 80C32 microcontroller core
in the LSI53C040 device. This microcontroller is compatible with the Intel
MCS51 family. It runs independently in interrupt mode.
The LSI53C040 SAF-TE firmware contains three major architectural
components, each implementing a separate I/O interface to the chip. The
SCSI block governs the SCSI interface and implementation of all the
SCSI commands used to send data packets to the host. The Two-Wire
Serial (TWS) interface bus is primarily used as an input bus. See
Section 2.5, “TWS Bus,” page 2-9 for more detailed information.
1.3 Features
This section describes the LSI53C040 SAF-TE firmware capabilities and
associated features, which include MPIO/MPLED Mapping, TWS
Interface Peripheral Support, the SAF-TE Interface, and Programmable
Enclosure Configuration monitoring.
1.3.1 MPIO/MPLED Mapping
Ability to assign MPIO/MPLED pins to dedicated functions such as
drive, power supply, and fan status monitoring
Automatically configures MPIO/MPLED pins
Generates listing of assigned pins
Ability to modify blink patterns for LEDs
1.3.2 TWS Interface Peripheral Support
National Semiconductor LM75 2-Wire Serial Digital Temperature
Sensor and Thermal Watchdog
Dallas Semiconductor DS1621 2-Wire Serial Digital Thermometer
and Thermostat
National Semiconductor LM78 fan, power supply, and temperature
monitoring
Features 1-3
1.3.3 SAF-TE Interface
The SAF-TE interface complies with the SAF-TE Specification R041497
and provides these features:
Supports Read Buffer Commands
Read Enclosure Configuration
Read Enclosure Status
ReadDeviceSlotStatus
Read Global Flags
Supports Write Buffer Commands
Write Device Slot Status
Performs Slot Operation
Send Global Commands
Supports the Upload Firmware command
Allows selection from one of 11 SCSI IDs (7–0, 15, 14, 13)
Allows connection from any data line, bits 8 through 15, to any one
of the SHID[2:0] (SCSI High ID) pins on the LSI53C040
Supports Slot Power Control Option
Supports Over Temperature LED Option
1-4 Using the Programming Guide
1.3.4 Programmable Enclosure Configuration Monitoring
The enclosure configuration monitoring allows:
Up to 14 device slots
Up to 6 fans and power supplies (single or dual input status)
Up to 15 binary temperature sensors (single input status)
Up to 4 temperature sensors (TWS)
Optional Ready device for use (slot power control) and Prepare
device for insertion/removal output signals
Programmable Vendor, Product, and Enclosure ID
Host Controllable Door Lock and Speaker Option
SelectionofoneortwoLEDsperdeviceslot
Global LED’s option for enclosure, drive, and array status
LSI53C040 Enclosure Services Processor Programming Guide 2-1
Chapter 2
General Design
Considerations
This chapter provides design information for firmware developers and
includes these topics:
Section 2.1, “8051/8032 Background,” page 2-1
Section 2.2, “The LSI53C040 Firmware,” page 2-7
Section 2.3, “SCSI and DMA,” page 2-8
Section 2.4, “8032-Based Timer,” page 2-9
Section 2.5, “TWS Bus,” page 2-9
Section 2.6, “Power-On/Start-up, page 2-10
Section 2.7, “Normal Processing,” page 2-10
Section 2.8, “Interrupts,” page 2-11
Section 2.9, “Debugging,” page 2-12
Section 2.10, “Setting Up A Development Environment, page 2-12
Section 2.11, “Configuration Examples,” page 2-25
2.1 8051/8032 Background
The user is encouraged to become familiar with the 8032 8-bit
microcontroller prior to reading this guide. The primary differences
between the 8051 and the 8032 are the internal RAM (256 bytes vs.
128 bytes for the 8051), also the 8032 has one additional timer. Several
excellent resources are available to aid the user in becoming familiar with
the 8032, including those listed in the Preface of this guide.
2-2 General Design Considerations
This section covers some of the key highlights of the 8032 architecture
and some important Archimedes compiler features. The remainder of the
chapter provides an overview of the LSI53C040 firmware and general
design considerations necessary to use this firmware most effectively.
2.1.1 8032 Architecture Features
The architectural features of the 8032 microcontroller are key to the
understanding and use of the LSI53C040 firmware. These features
include: Section 2.1.1.1, “Register Banks,” page 2-2, Section 2.1.1.2,
“Memory Areas,” page 2-2,andSection 2.1.1.3, “Special Function
Registers,” page 2-4.
2.1.1.1 Register Banks
Four register banks that contain eight registers each in the 8032 reside
in the lower 128 bytes of the internal RAM. See Figure 2.1 for an
example of these register banks.
2.1.1.2 Memory Areas
The 8032 architecture supports a number of physically separate memory
areas for program and data. Each memory area offers certain
advantages and disadvantages. Refer to the Intel 8-bit Embedded
Controllers databook or other 8051 reference material for more
information about the 8032 memory architecture. The following sections
briefly discuss program memory, the internal data memory, and the
external data memory.
Program Memory Since the 8032 is a ROMless variant of the 8051,
an external 16 Kbytes memory is required to hold the program code. The
LSI53C040 has the ability to automatically download this program code
from a serial EEPROM over the TWS bus into the external
16 Kbytes memory space.
Internal Data Memory The 8032 contains 256 bytes of internal data
memory, which can be read and written. The first 128 bytes of internal
data memory are both directly addressable and indirectly addressable.
The upper 128 bytes of data memory (from 0x80 to 0xFF) can be
addressed only indirectly. With indirect addressing, the referenced
register contains the address of the register or cell that actually contains
the data to be used. There is also a 16-byte area starting at 0x20 that is
bit-addressable. See Figure 2.1 for more detailed information.
8051/8032 Background 2-3
Figure 2.1 Internal RAM
External Data Memory Map The address decode block in the
LSI53C040 decodes addresses that are generated by the
microcontroller. Additionally, it multiplexes memory space accesses
between the different register and memory blocks according to the
memory map. See Figure 2.2 for an example of this memory map.
0x7F
Bit Addresses for This
RAM Area Only
0x00
Register
General
Purpose
Area
Bit
Address
Area
Register
Bank 3
Register
Bank 2
Register
Bank 1
R7
R6
R5
R4
R3
R2
R1
R0
0x7F
0x30
0x2F
0x20
0x1F
0x18
0x17
0x10
0x0F
0x08
0x07
0x06
0x05
0x04
0x03
0x02
0x01
0x00
Byte
Addresses
Bank 0
0x80
0xFF
Lower 128 Bytes Upper 128 Bytes
2-4 General Design Considerations
Figure 2.2 LSI53C040 Memory Map
2.1.1.3 Special Function Registers
The 8032 provides a distinct memory area for accessing Special
Function Registers (SFRs). SFRs are used in the program to control
timers, counters, serial I/Os, port I/Os, and peripherals. SFRs reside from
address 0x80 to 0xFF, and can be accessed by bits, bytes, and words.
The special function registers are listed in Table 2.2.
2.1.2 Archimedes Compiler Features
The user should be familiar with several Archimedes compiler features
that are related to the above 8032 features before reading the source
code.
2.1.2.1 Control Directives
The four control directives are: AREGS/NOAREGS, REGISTERBANK,
and SMALL.
Interrupt Vectors
16 Kbytes
Internal RAM
47 Kbytes External
Address Space
(Currently Not Used)
1 Kbyte Internal
Features Register
0x0000
0x0032
0x0033
0x3FFF
0x4000
0xFBFF
0xFC00
0xFFFF
/