## 7220 CONTROLLER FOR 1MBIT BPK 70A BUBBLE MEMORY SUBSYSTEM | 7220-1 | 0° To 75°C | |--------|----------------| | 7220-4 | 10°C To 55°C | | 7220-5 | − 20°C To 85°C | - Provides Interface between Host Microprocessor and 1 Mbit Bubble Subsystems - Interfaces to 8080/85/86/88/186/286 and other Standard Microprocessors - Controls Up to Eight BPK 70A-1, -4, Subsystems (or BPK70-1, -4) - Controls up to Four BPK 70A-5 Bubble Memory Subsystems or BPK70-5 - 16 Easy-to-Use Commands - Three Modes of Data Transfer - DMA - Polled - Interrupt - Transfer of Single (64 bytes) or Multiple Pages of Data The 7220 is a complete 1 Mbit Bubble Memory Controller (BMC) that provides the interface between the microprocessor host and the 1 Mbit Bubble Memory Subsystem. All communication between the host processor and the bubble memory is performed through the controller. The BMC interfaces easily to any Intel microprocessor or other standard microprocessor. The user has 16 easy-to-use commands available. Information such as the starting page location, the number of pages to be transferred and a read or write command is passed to the BMC before the read or write operation is initiated. The design engineer writes a bubble memory software driver to integrate the bubble memory into his system. This interfacing with the BMC is similar to interfacing a disk drive controller. Application notes and manuals describe the details of interfacing to the BMC. The BMC can transfer data in DMA, interrupt or polled mode. Data is transferred in and out of the bubble memory subsystem via the controller in single or multiple pages. A page size may vary from 64 bytes in a single bubble system and up to 512 bytes in an eight bubble system. (Maximum page size of 256 bytes for 7220-5.) The BMC has an eight bit data bus plus parity bit. Word length expansion to 16 bit is possible by operating two controllers in parallel. The BMC generates all the timing and control signals to the subsystem. One 7220-1 or 7220-4 BMC can control up to eight BPK 70A-1, -4 subsystems. This provides an easy expansion path to expand any 1 Mbit (128K byte) system by adding on additional subsystems. One 7220-5 can control up to four BPK 70A-5 subsystems. The BMC is manufactured using Intel's high performance HMOS process and is packaged in a standard 40-pin dual- in-line package. All inputs are directly TTL compatible and the device uses a single +5 Volt supply. #### HARDWARE DESCRIPTION The 7220 Bubble Memory Controller is packaged in a 40-pin Dual In-Line Package (DIP). The following lists the individual pins and describes their function. Table 1. Pin Description | Signal Name | Pin No. | 1/0 | Source/Destination | Description | |--------------------------------|---------|----------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | V <sub>CC</sub> | 40 | | | +5 VDC Supply | | GND | 20 | 1. | | Ground | | PWR.FAIL | 1 | , 1 | 7230 CPG | A low forces a controlled stop sequence and holds BMC in an IDLE state (similar to RESET). | | RESET.OUT | 2 | 0 | 7250 CPD/7242 FSA<br>7230 Reference<br>Current Switch | An active low signal to disable external logic initiated by PWR.FAIL or RESET signals, but not active until a stopping point in a field rotation is reached (if the BMC is causing the bubble memory drive field to be rotated). | | CLK | 3 | - T 57 | Host Bus | 4 MHz, TTL-level clock. | | RESET | 4 | <b>-</b> | Host Bus | A low on this pin forces the interruption of any BMC sequencer activity, performs a controlled shut-down, and initiates a reset sequence. After the reset sequence is concluded, a low on this pin causes a low on the RESET.OUT pin, furthermore, the next BMC sequencer command must be either the Initialize or Abort command; all other commands are ignored. | | RD | 5 | | Host Bus | A low on this pin enables the BMC output data to be transferred to the host data bus (D <sub>0</sub> -D <sub>8</sub> ). | | WR | 6 | - , | Host Bus | A low on this pin enables the contents of the host data bus $(D_0 \cdot D_8)$ to be transferred to the BMC. | | DACK | 7 | | Host Bus | A low signal is a DMA acknowledge. This notifies the BMC that the next memory cycle is available to transfer data. This line should be active only when DMA transfer is desired and the DMA ENABLE bit has been set. $\overline{CS}$ should not be active during DMA transfers except to read status. If DMA is not used, $\overline{DACK}$ requires an external pullup to $V_{cc}$ (5.1K ohm). | | DRQ | 8 | 0 | Host Bus | A high on this pin indicates that a data transfer between the BMC and the host memory is being requested. | | INT : | 9 | 0 | Host Bus | A high on this pin indicates that the BMC has a new status and requires servicing when enabled by the host CPU. | | A <sub>0</sub> | 10 | ı | Host Bus | A high on this pin selects the command/status registers. A low on this pin selects the data register. | | D <sub>0</sub> -D <sub>7</sub> | 11-18 | I/O | Host Bus | Host CPU data bus. An eight-bit bidirectional port which can be read or written by using the RD and WR strobes. D <sub>0</sub> shall be the LSB. | | D <sub>8</sub> | 19 | 1/0 | Host Bus | Parity bit. | Table 1. Pin Description (Continued) | Signal Name | Pin No. | 1/0 | Source/Destination | Description | | |-------------------------------------------------------------------------------|---------|-----|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | CS | 21 | 1. | Host Bus | Chip Select Input. A high on this pin shall disable the device to all but DMA transfers (i.e., it ignores bus activity and goes into a high impedance state). | | | DIO | 22 | I/O | 7242 FSA | A bidirectional active high data line that shall be used for serial communications with 7242 FSA devices. | | | SYNC | 23 | 0 | 7242 FSA | An active low output utilized to create time division multiplexing slots in a 7242 FSA chain. It shall also indicate the beginning of a data or command transfer between BMC and 7242 FSA. | | | SHIFT.CLK | 24 | 0 | 7242 FSA | A controller generated clock that initiates data transfer between selected FSAs and their corresponding bubble memory devices. The timing of SHIFT.CLK shall vary depending upon whether data is being read or written to the bubble memory. | | | BUS.RD | 25 | 0 | • | An active low signal that indicates that the DIO line is in the output mode, i.e., BMC is sending data to FSA. It shall be used to allow off-board expansion of 7242 FSA devices. | | | WAIT | 26 | I/O | * | A bidirectional pin that shall be tied to the WAIT pin on other BMCs when operated in parallel. It shall indicate that an interrupt has been generated and that the other BMCs should halt in synchronization with the interrupting BMC. WAIT is an open collector active low signal. Requires an external pullup resistor to V <sub>cc</sub> (5.1K ohm). | | | ERR.FLG | 27 | | 7242 FSA | An active low input generated externally by 7242 FSA indicating that an error condition exists. It is an open collector input which requires an external pullup resistor (5.1K ohm). | | | DET.ON | 28 | 0 | * | An active low signal that indicates the system is in the read mode and may be detecting. It is useful for power saving in the MBM. | | | C/D | 29 | 0 | 7242 FSA | A high on this line indicates that the BMC is beginning an FSA command sequence. A low on this line indicates that the BMC is beginning a data transmit or receive sequence. | | | BOOT.SW.EN | 30. | O, | 7230 CPG | An active low signal which may be used for enabling the BOOT.SWAP of the 7230 CPG. | | | SWAP.EN | .31 | 0 | 7230 CPG | An active low signal used to create the swap function in external circuits. | | | BOOT.EN | 32 | 0 | 7230 CPG | An active low signal enabling the bootstrap loop replicate function in external circuitry. | | | REP.EN | 33 | 0 | 7230 CPG | An active low signal used to enable the replicate function in external circuitry. | | | TM.B | 34 | 0 | 7230 CPG | An active low timing signal generated by the decoder logic for determining TRANSFER pulse width. | | | TM.A | 35 | 0 | 7230 CPG | An active low timing signal generated by the decoder logic for determining CUT pulse width. | | | $\frac{\overline{Y-}}{\overline{X-}}$ , $\frac{\overline{Y+}}{\overline{X+}}$ | 36-39 | 0 | 7250 CPD | Four active low timing signals generated by the decoding logic and used to create coil drive currents in the bubble memory device. | | #### **FUNCTIONAL DESCRIPTION** The 7220 Bubble Memory Controller provides the user interface to the bubble memory system. The BMC generates all memory system timing and control, maintains memory address information, interprets and executes user request for data transfers, and provides a Microprocessor-Bus compatible interface for the magnetic bubble memory system. Figure 3 is a block diagram of the 7220 Bubble Memory Controller (BMC). The following paragraphs describe the functions of the individual functional sections of the BMC. Figure 3. 7220 Bubble Memory Controller (BMC), Block Diagram System Bus Interface — The System Bus Interface (SBI) logic contains the timing and control logic required to interface the BMC to a non-multiplexed bus. The logic also contains the circuitry to check and generate odd parity on transfers across the bus. The interface has input data, output data, and status data latches. The BMC can interface asynchronously to the host CPU. With a 4-MHz clock, it is capable of sustaining a 1.14 Mbyte per second transfer rate, while data is available in the BMC FIFO. FIFO—The FIFO consists of a $40 \times 8$ bit FIFO RAM for data storage. The FIFO block also contains input and output data latches, providing double data buffering, to improve the R/W cycle times seen at the system bus interface. The FIFO may be used as a general purpose FIFO when a command is not being executed by the BMC Sequencer. In this mode, the FIFO READY status bit becomes a FIFO not-empty indicator indicating that the RAM and input/output latches have at least one byte of data. DMA and Interrupt Logic — The DRQ pin has two functions: - (1) If the DMA enable bit in the enable register is set, the DRQ pin, in conjunction with the DACK pin, provides a standard DMA transfer capability; i.e., it has the ability to handshake with an 8257 or 9517/8237 DMA controller chip. - (2) If the DMA enable bit is reset, the DRQ pin acts as a "ready for data transfer interrupt" pin. It becomes active when 22 bytes may be read from or written into the BMC; it is reset when this condition no longer exists. Register File—The register file contains 7 eight-bit registers that are accessible by the host CPU. Refer to the Register Section for details. MBM Address Logic and RAM—The MBM address logic consists of the block length counter, starting address counter, adder, and MBM Address RAM. The MBM Address RAM is used to store the next available page address for each of up to 8 dual FSAs. The address maintained is the read address; the write address is generated, when needed, by adding a constant to the stored read address. The block length counter enables multiple page transfers of up to 2048 pages in length. The starting address counter is used as a register to hold the desired start address. Once the start address is reached, the counter is incremented on each subsequent page transfer so that its value is equal to the present read address. DIO Bootloop Decoder/Encoder — Performs parallel-to-serial and serial-to-parallel conversions between the FIFO data and the serial bit stream on the DIO line. This block also generates the BUS.RD signal, which indicates the direction of data transfer on the DIO line (this is useful in situations which require external buffering on the DIO line). This block also contains the circuitry which decodes the bootloop data during a Read Bootloop or Initialize operation, and encodes the bootloop data during a Write Bootloop operation. Sequencer—Controls the execution of commands by decoding the contents of its own internal ROM in which the BMC firmware is located. This block also sets and resets flags and status bits, and controls actions in other parts of the BMC. Power Fail and Reset—Provides a means of resetting the bubble systems in an orderly manner, when activated by the PWR.FAIL signal, the RESET signal, or the ABORT command. The additive noise on the PWR.FAIL pin should be less than 150 mV for proper powerfail operation. FSA Select Logic block contains the logic which controls the timing of the interaction between the BMC and the FSAs. The FSA selection is determined by the four high-order bits in the BLR and the four high-order bits in the AR, both set by the user. Bubble Signal Decoder block contains the logic for creating all the MBM timing signals. The BMC to bubble memory interface consists of active low timing signals. The starting and stopping point of each signal is determined by the decoder logic. Each signal may occur every field rotation or only once in a number of field rotations. The field rotation in which a timing pulse occurs is controlled by the sequencer logic. Figure 4 and Table 2 illustrate the typical timing signals for the BMC. These signals are described in the following paragraphs. $\overline{X}+$ , $\overline{X}-$ , $\overline{Y}+$ , and $\overline{Y}-$ go to the 7250 CPDs, and are used to enable the coil drive currents in the MBMs. TM.A and TM.B go to the 7230 CPGs, and are used to determine, respectively, the pulse widths for the CUT and TRANSFER functions used in replicating and generating the bubbles. Table 2. 7220 BMC Timing (Degrees)\*\* | Signal | Start | Width | End | |----------------|---------|-------|---------| | <del>X +</del> | 270° | 108° | 378° | | <u>Y</u> + | 0° | 108° | 108° | | <del>X –</del> | 90° | 108° | 198° | | <u>Y</u> – | 180°, | 108° | 288° | | TM.A (ODD) | 270° | 4° | 274.5° | | TM.A (EVEN) | 90° | 4° | 94.5° | | TM.B (ODD) | 270° | 90° | 360° | | TM.B (EVEN) | 90° | 90° | 180° | | BOOT.EN | 252° | 108° | 360° | | REP.EN | 252° | 108° | 360° | | SWAP.EN | 180° | 5.7° | 697° | | BOOT.SW.EN | 180° | DC* | 180° | | SHIFTCLK (RD) | 186.75° | 99° | 285.75° | | SHIFTCLK (WR) | , 72° | 288° | 360° | <sup>\*</sup>Stays low for 4118 field rotation periods when writing the MBM Bootloop. SWAP.EN, REP.EN, BOOT.SW.EN, and BOOT.EN all go to the 7230 CPG. They are used to enable, respectively, the data swap, data replicate, boot swap, and boot replicate functions within the MBMs. SHIFT.CLK goes to the FSAs. It is used to control the timing of events at the interface between each FSA and its corresponding MBM. (Refer to 7242 FSA Specification for a description of the BMC/FSA interface.) $\overline{\text{SYNC}}$ and $\overline{\text{C/D}}$ control the serial communications between the BMC and the FSAs (on the DIO line). #### **USER-ACCESSIBLE REGISTERS** The user operates the bubble memory system by reading from or writing to specific registers within the bubble memory controller (BMC). The following paragraphs identify these registers and gives brief functional descriptions, including bit configurations and address assignments. #### Register Addressing Selection of the user-accessible registers depends on register address information sent from the user to the BMC. This address information is sent via a single address line (designated $A_0$ ) and data bus lines $D_0$ through $D_4$ . Both Command Register (CMDR) and Register Address Counter (RAC) are 4-bit registers which are loaded from $D_0$ - $D_3$ . The status register is selected and read by a single read request. The command register is selected and loaded by a single write request. The remaining registers are accessed indirectly, and the desired register is first selected by placing its address in the RAC, and then read or written with a subsequent read or write request. <sup>\*\*</sup>All phases relative to $\overline{Y}$ - start phase. All entries $\pm$ 1.26° except $\overline{TM.A}$ width which is $\pm$ 0.5°. Figure 4. 7220 BMC Timing Diagram Table 3 gives a complete listing of the address asignments for the user-accessible registers. The registers are listed in two groups. The first group (STR, CMDR, RAC) consists of those registers that are selected and accessed in one operation. The second group (UR, BLR, ER, AR, FIFO) consists of those registers that are addressed indirectly by the contents of RAC. Table 3. Address Assignments for the User-Accessible Registers | A0 D7 D6 D5 D4 D3 D2 D1 D0 | Symbol | Name of Register | Read/Write | |----------------------------|--------|-----------------------------|------------| | 1 10:10 0 1 C.C.C.C.C. | | Command<br>Register | | | 1 0 0 M 0 B B B B | | Register Address<br>Counter | | | 1 S.S.S.S.S.S.S.S. | STR | Status Register | Read Only | Table 3. Address Assignments for the User-Accessible Registers (Continued) | RAC<br>A0 B3 B2 B1 | B0 Symbol | Name of Register | Read/Write | |--------------------|-----------|------------------------------|---------------| | 0 1 0 1 | 0 UR | Utility Register | Read or Write | | 0 1 0 1 | 1 BLR LSB | Block Length<br>Register LSB | Write Only | | 0,: 1 1,.,0 | 0 BLR MSB | Block Length<br>Register MSB | Write Only | | 0 1 1 0 | 1 ER | Enable Register | Write Only | | 0 1 1 1 | 0 AR LSB | Address Register<br>LSB | Read or Write | | 0 1 1 1 | 1 AR MSB | Address Register<br>MSB | Read or Write | | 0 0 0 0 | 0 FIFO | FIFO Data Buffer | Read or Write | SSSSSSS = 8-bit status information returned to the user from the STR CCCC = 4-bit command code sent to the CMDR by the user. BBBB = 4-bit register address sent to the RAC by the user. B3B2B1B0 = 4-bit contents of RAC at the time the user makes a read or write request with A0 = 0. LSB = Least Significant Byte MSB = Most Significant Byte M = Modifier The register file contains the registers with address 1010 through 1111. These registers are also called parametric registers because they contain flags and parameters that determine exactly how the BMC will respond to commands written to the CMDR. To facilitate such operations, the BMC automatically increments the RAC by one count after each transfer of data to or from a parametric register. The RAC increments from the initially loaded value through address 1111 and then on to 0000 (the FIFO address). When it has reached 0000, it no longer increments. All subsequent data transfers (with A0 = 0) will be to or from the FIFO until such time as the RAC is loaded with a different register address. #### REGISTER DESCRIPTIONS #### Command Register (CMDR) 4 Bits, Write Only The user issues a command to the BMC by writing a 4-bit command code to the CMDR. Table 4 lists the 4-bit command codes used to issue the sixteen commands recognized by the BMC: Table 7 is a listing of the commands and their functions. Table 4. Command Code Definitions | D3 | D2 | D1 | Do | Command Name | |-----|------|----|--------|--------------------------------| | 0 | 0 | 0. | 0 | Write Bootloop Register Masked | | 0 | 0 | 0 | 0 | Initialize | | 0 | 0. | .1 | 0 | Read Bubble Data | | 0 | 0 | 1 | . 1 . | Write Bubble Data | | 0 . | 1 | 0 | 0 | Read Seek | | 0 | 1 | 0 | 1 | Read Bootloop Register | | 0 | 1 | 1 | 0 | Write Bootloop Register | | 0 | . 1 | 1 | .1 | Write Bootloop | | 1 | 0 | 0 | 0 | Read FSA Status | | 1 | 0 | 0 | - 1 | Abort | | 1 | 0 | 1 | , .0 . | Write Seek | | 1 | 0 | 1 | 1 | Read Bootloop | | 1. | 1.1. | 0 | 0 | Read Corrected Data | | 1 | 1 | 0 | 1 | Reset FIFO | | 1 | 1 | 1 | 0 | MBM Purge | | 1 | 1 | 1 | 1 | Software Reset | The most commonly used commands in normal operation are: Initialize Read Bubble Data Write Bubble Data Reset FIFO Read Seek Write Seek Abort Read Corrected Data Software Reset Read FSA Status MBM Purge Commands relating to the bootloop, and used only for diagnostic purposes, are: Read Bootloop Register Write Bootloop Register Write Bootloop Register Masked Read Bootloop Write Bootloop #### Status Register (STR) 8 Bits, Read Only The user reads the BMC status register in response to an interrupt signal, or as part of the polling process in a polled data transfer mode. The status register provides information about error conditions, completion or termination of commands, and about the BMC's readiness to transfer data or accept new commands. The individual bit descriptions are as follows: BUSY (when = 1) indicates that the BMC is in the process of executing a command. When equal to 0, BUSY indicates that the BMC is ready to receive a new command. In the case of Read Bubble Data, Read Bootloop, read Bootloop Register, or Read Corrected Data commands, BUSY may also indicate that the data has not been completely removed from the FIFO, and that DRQ is still active. BUSY will then drop as soon as DRQ does (after the user has finished reading the data remaining in the FIFO). OP COMPLETE (when = 1) indicates the successful completion of a command. OP FAIL (when = 1) indicates that the BUSY bit has gone inactive with either the TIMING ERROR or UNCORRECTABLE ERROR bits active. TIMING ERROR (when = 1) indicates that a FSA has reported a timing error to the BMC, or that the host system has failed to keep up with the BMC, thereby causing the BMC FIFO to overflow or to underflow. TIMING ERROR is also set if no bootloop sync word is found during initialization, or if a Write Bootloop command is issued when the WRITE BOOTLOOP ENABLE bit is equal to zero in the enable register. CORRECTABLE ERROR (when = 1) indicates that a FSA has reported to the BMC that a correctable error has been detected in the last data block transferred. UNCORRECTABLE ERROR (when = 1) indicates that at least one FSA has reported to the BMC that an uncorrectable error has been detected in the last data block transferred. PARITY ERROR (when = 1) indicates that the BMC's parity check circuitry has detected a parity error on a data byte sent to the BMC by the user on the data lines $D_0 \cdot D_8$ . FIFO READY has two functions. The FIFO READY functions are as follows: NOTE: IF RAC ≠ FIFO, FIFO READY = 1 | STATUS B | ITS | READ WRI | WRITE | |------------|--------|-----------------|-----------------------------------------| | FIFO READY | BUSY | TILAD | *************************************** | | 1 | 1 | data in<br>FIFO | space in<br>FIFO | | . 0 | 1, | no data | no space | | 1<br>0 | 0<br>0 | | in FIFO —<br>empty — | Although the status word can be read at any time, the status information, bit 1 through 6, is not valid until the BUSY bit is low. STR Bits 1 through 6 are reset when a new command is issued. They may also be reset by making a write request (WR=0) to the BMC with $A_0=1$ , $D_4=0$ , and $D_5=1$ (Modifier Bit) (that is, writing the RAC with $D_5=1$ ). This operation also resets the "INT" pin to "0". NOTE: A byte of FIFO data can be lost when using this procedure if the RAC is written to other than the FIFO address when data is still present in FIFO. #### Enable Register (ER) 8 Bits, Write Only The user sets various bits of the enable register to enable or disable various functions within the BMC or the FSAs. The individual bit descriptions are as follows: In the above figure and in the text below, the following abbreviations are used: ICD = INTERNALLY CORRECT DATA RCD = READ CORRECTED DATA UCE = UNCORRECTABLE ERROR CE = CORRECTABLE ERROR TE = TIMING ERROR ENABLE PARITY INTERRUPT enables the BMC to interrupt the host system (via the INT line) when the BMC detects a parity error on the data bus lines $D_0$ - $D_7$ . ENABLE ICD enables the BMC to give the Internally Correct Data command to the FSAs when an error has been detected by the FSA's error detection and correction circuitry. Each FSA responds to such a command by internally cycling the data through its error correction network. When finished, the FSA returns status to the BMC as to whether or not the error is correctable. The value of ENABLE ICD affects the action of INTERRUPT ENABLE (ERROR). ENABLE RCD enables the BMC to give the Read Corrected Data command to the FSAs when an error has been detected. This causes each FSA to correct the error (if possible) and also to transfer the corrected data to the BMC. The Read Corrected Data command is also used to read into the BMC data previously corrected by the FSA in response to an Internally Correct Data command. In either case, when the data transfer has been completed, the BMC reads each FSA's status to determine whether or not the error was correctable. In the case of an uncorrectable error, bad data may have been sent to the user. The value of ENABLE RCD affects the action of INTERRUPT ENABLE (ERROR). WRITE BOOTLOOP ENABLE (when = 1) enables the bootloop to be written. If this bit is equal to zero, and a Write Bootloop command is received by the BMC, the command is aborted and the TIM-ING ERROR bit is set in the STR. MFBTR controls the maximum burst transfer rate from FSA(s) to BMC FIFO. This rate is variable on the "last page" of a multiple page transfer. (In one page transfers the last page is the only page.) See Table 5 for effects of this bit on the various 7220 commands. Table 5. MFBTR Bit Definitions | Number of MBMs | Maximum<br>Required | MFB | TR Bit | |----------------------|-----------------------------|--------------|---------------| | Operated in Parallel | Host Interface<br>Data Rate | Read Command | Write Command | | 1 | 50K byte/sec | 0 | N/A | | 2 | 100K byte/sec | 0 | N/A | | . 4 | 200K byte/sec | 0 | N/A | | . 8 | 400K byte/sec | . 0 | N/A | | ⇔ (* <b>1</b> | 12.5K byte/sec | 1 | 0 | | 2 | 25K byte/sec | 1 | 0 1 6 7 | | 4 . | 50K byte/sec | 1 | 0 | | - 8 | 100K byte/sec | 1 | 0 | NOTE: The MFBTR bit should always be set to "0" for all commands, except "Read Bubble Data." DMA ENABLE (when = 1) enables the BMC to operate in DMA data transfer mode, using the DRQ and DACK signals in interaction with a DMA controller. When equal to zero, DMA ENABLE sets up the controller to support interrupt driven or polled data transfer. INTERRUPT ENABLE (ERROR) selects error conditions under which the BMC stops command execution and interrupts the host processor (via the INT line). INTERRUPT ENABLE (ERROR) operates in conjunction with ENABLE ICD and ENABLE RCD. | Enable<br>ICD | Enable<br>RCD | Interrupt<br>Enable<br>(ERROR) | Interrupt Action | |---------------|---------------|--------------------------------|-----------------------------| | 0 | 0 | 0 | No interrupts due to errors | | 0 | 0 | 1 | Interrupt on TE only | | 0 | - 1 | 0 | Interrupt on UCE or TE | | 0 | 1 | 1 | Interrupt on UCE, CE, or TE | | 1 | 0 | 0 | Interrupt on UCE or TE | | 1 | . 0 | 1 | Interrupt on UCE, CE, or TE | | . 1 . | 1 | 0 | Not used | | 1 | 1 | 1 | Not used | TE = Timing Error, CE = Correctable Error, UCE = Uncorrectable Error. INTERRUPT ENABLE (NORMAL) (when = 1) enables the BMC to interrupt the host system (via the INT line), when a command execution has been successfully completed (OP COMPLETE = 1 in the STR). #### Utility Register (UR) 8 Bits, Read or Write The utility register is a general purpose register available to the user in connection with bubble memory system operations. It has no direct effect on the BMC operation, but is provided as a convenience to the user. ## Block Length Register (BLR) 16 Bits, Write Only The contents of the block length register determine the system page size and also the number of pages to be transferred in response to a single bubble data read or write command. The bit configuration is as follows: NUMBER OF FSA NUMBER OF PAGES TO BE TRANSFERRED The system page size is proportional to the number of magnetic bubble memory modules (MBMs) operating in parallel during the data read or write operation. Each MBM requires two FSA channels. Bits 4 through 7 of BLR MSB actually specify the number of FSA channels to be accessed. The BLR LSB, together with the 3 least significant bits of the BLR MSB, specify the number of pages to be transferred. Up to 2048 pages can be transferred in response to a single bubble data read or write command, hence the requirement for 11 bits. All 11 bits equal to zero specifies a 2048 page transfer. #### Address Register (AR) 16 Bits, Read or Write The contents of the address register determine which MBM group is to be accessed, and, within that group, what starting address location shall be used in a data read or write operation. The bit configuration is as follows: Within each MBM there are 2048 possible starting address locations for a data read or write operation, hence the requirement for 11 bits in the starting address. The selection of the MBMs to be read or written is specified by AR MSB Bits 3-6. The BMCs interpretation of these bits depends on the number of MBMs in a group, which is specified by BLR MSB Bits 4-7. Table 6 shows which MBM groups are selected in response to given values for BLR MSB Bits 4-7 and AR MSB Bits 3-6. A 1-megabyte system (8 MBMs) is represented, with the FSA channels numbered 0 through F: Table 6. Selection of FSA Channels | AR MSB Bits | BLR MSB Bits (7,6,5,4) | | | | | |--------------------------------------------------------------------------------------------------------------|---------------------------------|------------------------------------------------------|------------------------------------------|------------------|--------| | (6,5,4,3) | 0000 | 0001 | 0010 | 0100 | 1000 | | 0000<br>0001<br>0010<br>0011<br>0100<br>0101<br>0110<br>0111<br>1000<br>1001<br>1010<br>1101<br>1100<br>1111 | 0 1 2 3 4 5 6 7 8 9 A B C D E F | 0,1<br>2,3<br>4,5<br>6,7<br>8,9<br>A,B<br>C,D<br>E,F | 0,1,2,3<br>4,5,6,7<br>8,9,A,B<br>C,D,E,F | 0 to 7<br>8 to F | 0 to F | The accessing of single FSA channels is done only as part of diagnostic processes. AR MSB Bit 7 is not used. # FIFO Data Buffer (FIFO) 40 × 8 Bits, Read or Write The BMC FIFO is a 40-byte buffer through which data passes on its way from the FSAs to the user, or from the user to the FSAs. The FIFO allows the data transfer to proceed in an asynchronous and flexible manner, and relaxes timing constraints, both to the FSAs and also to the user's equipment. The user's system must, however, meet the data rate requirements. When the BMC is busy (executing a command) the FIFO functions as a data buffer. When the BMC is not busy, the FIFO is available to the user as a general purpose FIFO. #### **FUNCTIONAL OPERATION** The IC components used in the bubble memory systems have been designed with transparency in mind—that is, a maximum number of operations are handled by the hardware and firmware of these components. Each one-Megabit Bubble Memory (MBM) operates in its own domain, and is unaffected by the number of bubble memories in the system. The roles played by the MBM's immediate support circuitry can be described as if the system contained only one MBM module. #### Data Flow Within the Magnetic Bubble Memory (MBM) System (Single MBM Systems) During a read operation, data flows as follows: The data from the MBM is input to the Formatter/Sense Amplifier (FSA). Data from each channel (A channel or B channel) of the MBM goes to the corresponding channel of the FSA. In the FSA, the data is paired up with the corresponding bit in the FSA's bootloop register to determine whether it represents data from a 'good' loop. If it does, the data bit is stored in the FSA FIFO. Error detection and correction (if enabled by the user) is applied to each block of 256 data bits. From the FSA FIFO, data is sent to the bubble memory controller (BMC) in the form of a serial bit stream, via a one-line bidirectional data bus (DIO). The data is multiplexed onto the DIO line, with data bits coming alternately from the A and B channels of the FSA. The BMC outputs a SYNC pulse to the SELECT.IN input of the FSA. The FSA responds by placing a data bit from the A channel FIFO on the DIO line. One clock cycle later, a data bit from the B channel FIFO is placed on the DIO line. The BMC continues to output SYNC pulses, once every 20 or 80 clock cycles, each time receiving two data bits in return. In the BMC, the data undergoes serial-to-parallel conversion, and is assembled into bytes, which are then placed in the BMC FIFO, which can hold 40 bytes of data. From this FIFO, the data bytes are written onto the user interface. During a write operation, the data flow consists of the corresponding operations in the reverse order. #### INTERFACING REQUIREMENTS All communications between the host microprocessor, and the bubble memory is performed through the 7220 BMC. The BPK 72 Bubble Memory Prototype Kit User's Manual, Order Number: 121685, contains detailed information on how to use and interface the BMC. Below the general principles are described, for detailed guidelines please refer to the BPK 72 Manual. For software considerations, please also see Application Note AP-157. (Order Number: 230707) First the hardware interfacing requirements and second the software interfacing requirements are described. # HARDWARE INTERFACE REQUIREMENTS User Interface Signals The source, destination and function of the user interface signals are described in Table 1 in the data sheet. **Table 7. Detailed Command Descriptions** | Initialize | The BMC executes the Initialize command by first interrogating the bubble system to determine how many FSAs are present, then reading and decoding the bootloop from each MBM and storing the results in the corresponding FSA's bootloop register. All the parametric registers must be properly set up before issuing the Initialize command. | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Read Bubble Data | The Read Bubble Data command causes data to be read from the MBMs into the BMC FIFO. The selection of the MBMs to be accessed and the starting address for the read operation is specified in the address register (AR). The block length register (BLR) specifies the number of system pages to be read. All the parametric registers must be properly set up before issuing the Read Bubble Data command. | | Write Bubble Data | The Write Bubble Data command causes data to be read from the BMC FIFO and written into the MBMs. The selection of the MBMs to be accessed and the starting address for the write operation is specified in the address register (AR). The block length register (BLR) specifies the number of system pages to be written. All the parametric registers must be properly set up before issuing the Write Bubble Data command. | | Read Seek | The Read Seek command rotates the selected MBMs to a designated page address location. No data transfer occurs. The positioning is such that the next data location available to be read is the specified (in AR) page address plus one. The Read Seek command may be used to reduce latency (access time) in cases where information is available for the user to predict the location of an impending read reference to the MBMs. | #### **Table 7. Detailed Command Descriptions (Continued)** | Write Seek | The Write Seek command rotates the selected MBMs to a designated page address location. No data transfer occurs. The positioning is such that the next data location available to be written is the specified (in AR) page address plus one. The Write Seek command may be used to reduce latency (access time) in cases where information is available for the user to predict the location of an impending write reference to the MBMs. | |-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Abort | The Abort command causes a controlled termination of the command currently being executed by the BMC. The Abort command will be accepted by the BMC (and is typically issued) when the BMC is busy. | | MBM Purge | The MBM Purge command clears all BMC registers, counters, and the MBM address RAM Furthermore, it determines how many FSA channels are present in the system and stores this value in the 7220. The "INITIALIZE" command uses this command as a subroutine. | | Read Corrected Data | The Read Corrected Data command causes the BMC to read into the BMC FIFO a 256-bit block of data from the FIFO of each selected FSA channel, after an error has been detected. The data cycles through the error correction network of the FSA. After the data has been read, the FSA reports to the BMC whether or not the error was correctable. The Read Corrected Data command is used only when the system is in error correction mode (ENABLE ICD or ENABLE RCD set in the ER). | | Software Reset | The Software Reset command clears the BMC FIFO and all registers, except those containing initialization parameters. It also causes the BMC to send the Software Reset command to selected FSAs in the system. No reinitialization is needed after this command. | | Read FSA Status | The Read FSA Status command causes the BMC to read the 8-bit status register of all FSAs, and to store this information in the BMC FIFO. The Read FSA Status command is independent all parametric registers. | | Read Bootloop<br>Register | The Read Bootloop Register command causes the BMC to read the bootloop register of the selected FSA channels and to store this information in the BMC FIFO. Twenty bytes are transferred for each FSA channel selected. | | Write Bootloop<br>Register Masked | Proper operation of the FSAs during data transfer to or from the MBMs requires that the bootloop register contain (if error correction is used) exactly 270 logic 1s for each FSA bootloop register. The user may select any subset of 270 "good" loops from the total number of available loops (if error correction is not used, 270 replaced by 272). As an alternative, the Write Bootloop Register Masked command may be used. This command counts the number of logic 1s and masks out the remaining 1s after the proper count has been reached. The Initialize command uses this command as a subroutine. | | Read Bootloop | The Read Bootloop command causes the BMC to read the bootloop from the selected MBM, and to store the decoded bootloop information in the BMC FIFO. The Initialize command uses this command as a subroutine. | | Write Bootloop | The Write Bootloop command causes the existing contents of the selected MBM's bootloop to be replaced by new bootloop data based on 40 bytes of information stored in the FIFO (the user must actually write 41 bytes, where the 41st byte is all 0s). Encoding of the bootloop data is done by the BMC hardware. | #### **System Timing** As shown on the timing diagrams in the WAVEFORM section the typical read/write cycle timing provides sufficient tolerance to allow most currently available microprocessors to be easily adapted to the BMC timing requirements. #### **User Data Transfer Rate Requirements** The maximum data rate for the user interface is a function of the number of MBMs operated in parallel as outlined in table 8. The rates listed must be considered in relation to the data transfer mode (polled, interruptdriven, or DMA) to be implemented in order to be sure that the host system software and hardware are capable of keeping up with the data transfer. In other words, the BMC requires the host CPU to be able to sustain the maximum data rate transfer rate for the minimum data transfer (e.g., for a one bubble system keep up the transfer rate for at least 64 bytes = one page). | Table 8. User Data User Transfer Rate Rec | uirements | |-------------------------------------------|-----------| |-------------------------------------------|-----------| | Number of MBMs Operating | Maximum Data Transfer Rate Between BMC FIFO and the FSAs during Write | Maximum Data Transfer Rate<br>Between BMC FIFO and the<br>FSAs during Read Bubble<br>Data Commands | | | |--------------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------|--| | in Parallel | Bubble Data Commands | MFBTR = 0 | MFBTR = 1 | | | 1 | 12.5 kbytes/second | 50 kbytes/second | 12.5 kbytes/second | | | 2 | 25 kbytes/second | 100 kbytes/second | 25 kbytes/second | | | 4 | 50 kbytes/second | 200 kbytes/second | 50 kbytes/second | | | | 100 kbytes/second | 400 kbytes/second | 100 kbytes/second | | #### Hardware Interfacing for Data Transfer The BMC supports three data transfer modes, i.e. DMA, interrupt-driven and polled. To support DMA, a hardware mechanism is required for servicing the BMC's data transfer requests. While several hardware implementations are possible, one common configuration is the Intel 8257 DMA controller. To support an interrupt-driven system an Intel 8259 Programmable Interrupt Controller is often used. The polled data transfer mode relies almost exclusively on the software interaction between the host processor and the BMC to control the transfer of data. #### Multiple MBM-System A BMC is capable of processing data and of supplying the required timing and control signals for operating up to four Bubble Storage Units (BSUs), each of which is capable of storing 128 kbytes of user data. A BSU consists of a 128 kbyte MBM and its five immediate IC support chips (i.e. a MBPK 70A-5 Kit). #### SOFTWARE INTERFACE REQUIREMENTS To use the BMC, the user has to write a "bubble memory software driver". The bubble driver is responsible for all the system interaction with the bubble memory controller and is intrinsic to the efficient and reliable operation of the bubble system. The driver accepts bubble memory commands and command execution parameters from the application program, controls and monitors command execution, and returns operational status information to the application program at command completion. To perform all of these operations, the bubble driver must support the bit/byte level of the bubble memory controller's command and status registers and the parametric registers that define the operating mode, system configuration, and extent of the transfer. The level of the software driver complexity is a function of the specific application needs. Regardless, a set of basic drivers must be developed that in turn are integrated into a system at the appropriate level. If an application program is small and simple, a basic bubble driver may simply be called from the main program. At the highest level of driver sophistication, the application program treats the bubble system as a collection of named data areas of files similar to the way in which data is stored and retrieved in disk operating systems. At the file system level, an application program can ignore the mechanics of bubble storage and access and merely present a file name to the driver to open, read, or write, then close the desired bubble file. #### **Data Organization** From a software viewpoint, data logically is organized into blocks of bytes called pages. During data transfer operations, one or more of these pages are transferred between the bubble(s) and the host microprocessor. A page is the smallest increment of data that can be transferred; single bytes cannot be transferred. Conceptually, the data organization within a bubble memory is analogous to a disk system. Just as disk sector sizes are fixed when a disk is formatted, bubble page sizes are established, under software control when the bubble system is initialized. For a single bubble system, the page size is fixed at either 64 bytes when error correction is implemented or 68 bytes without error correction, and the total number of pages available is 2048. In systems with multiple bubbles, page size can vary from 64 bytes (68 bytes without error correction) to 256 bytes (272 bytes without error correction) depending on the number of bubble devices in the system. Page size is directly proportional to the system data rate and also determines the total number of available pages (address field size). The selection of the appropriate page size depends primarily on the data rate supported by the system. The higher the data rate, the faster the microprocessor must respond to the demands of the bubble memory controller. #### **Buffering** The bubble memory controller includes a FIFO data buffer that, although only 40 bytes long, reconciles timing differences between the parallel data transfer to or from the host microprocessor and the serial data transfer to or from the Bubble Memory Subsystem. Accordingly, when an application program requests data from a bubble, the software driver is responsible for keeping up with the FIFO for the duration of the data transfer in order to prevent the FIFO from overflowing or underflowing. #### **Command Execution** Command execution can be performed either in an interrupt driven mode or in a polled mode irrespective of the data transfer mode (polled, interrupt-driven, or DMA). #### **Data Transfer Mode** As described earlier in the hardware section, three data transfer modes are available (polled, interrupt-driven or DMA). System performance, additional hardware and software overhead are all important considerations when choosing the appropriate mode for your application. #### **Error Correction** The bubble memory system has a built-in error correction. To insure highest data integrity, the error correction should always be used. Three levels of error correction are available. #### Communication with the BMC All communications between the host and the bubble memory actually are performed through the BMC. The BMC has two input/output (I/O) ports, an eight-bit bidirectional data port, and an eight-bit command/status port. Conceptually, a bubble memory system can be thought of as a disk system in that data in the bubble memory is organized into blocks called pages in bubble technology that are similar to disk sectors. Information such as starting page location, direction of transfer, and the number of pages to be transferred is passed to the BMC before the desired read or write operation is initiated. The general procedure for communicating with the BMC is: Set-up the BMC for data transfer communication by loading specific parameters in user-accessible registers. Send the desired command. Read the status register to determine if command is accepted. If applicable, transfer (i.e., read or write) data. Read the status register until BMC is not busy (or under some conditions "INT" pin). Examine the status register to determine whether the operation was successful. For all details and exceptions to this general description, see AP-157 or the BPK 72 User's Manual. #### ABSOLUTE MAXIMUM RATINGS Temperature under bias ...... -40 to +100°C Storage Temperature ..... -65°C to +150°C All Input or Output Voltages and VCC Supply Voltage ..... -0.5V to 7V \*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. ### **D.C. CHARACTERISTICS** ( $T_A$ = see front page; $V_{CC}$ = 5.0V +5%, -10%; \* = 7220-5) | Symbol | Parameter | Min. | Max. | Unit | Test Condition | |--------------------|----------------------------------------------------------------------------|-----------|-----------------------|----------|-------------------------------------------| | V <sub>IL</sub> | Input Low Voltage | | 0.8 | ٧ | , | | V <sub>IH(1)</sub> | Input High Voltage (all but PWR.FAIL) | 2.0(2.2*) | V <sub>CC</sub> +0.5V | ٧ | | | V <sub>IH(2)</sub> | Input High Voltage (PWR.FAIL) | 2.5 | V <sub>CC</sub> +0.5V | · V | | | V <sub>OL(1)</sub> | Output Low Voltage (All outputs except DET.ON, BUS.RD, SHIFT.CLK, and SYNC | \$ 15 mg | .45 | <b>v</b> | I <sub>OL</sub> = 3.2 mA | | V <sub>OL(2)</sub> | Output Low Voltage<br>DET.ON, BUS.RD, SHIFT.CLK, SYNC | | .45 | ٧ | I <sub>OL</sub> = 1.6 mA | | V <sub>OH</sub> | Output High Voltage | 2.4 | 2 | V | $I_{OH} = 400 \mu A$ | | կլ | Input Leakage Current | | 10 | μΑ | $0 \le V_{IN} \le V_{CC}$ | | OFL | Output Float Leakage | - | 10 | . μΑ | $0.45 \leqslant V_{OUT} \leqslant V_{CC}$ | | Icc | Power Supply Current from V <sub>CC</sub> | | 200 | mÁ | | #### A.C. CHARACTERISTICS $(T_A = \text{see front page}; V_{CC} = 5.0V + 5\%, -10\%, C_L = 150pF; \text{ unless otherwise noted.})$ | Symbol | Parameter | Min. | Max. | Unit | Test Condition | |--------------------------------|---------------------------------|--------------------|--------------------|------|---------------------------------------| | t <sub>P</sub> - expec | Clock Period | 249.75 | 250.25 | ns | · · · · · · · · · · · · · · · · · · · | | tø | Clock Phase Width (High Time) | .45 t <sub>P</sub> | .55 t <sub>P</sub> | | | | t <sub>R</sub> -t <sub>F</sub> | Input Signal Rise and Fall Time | - | 30 | ns | | #### FSA INTERFACE TIMINGS (under pin loading) | Symbol | Parameter | Min. | Max. | Unit | Test Condition | |-------------------|---------------------------------|------|------|------|------------------| | t <sub>CDV</sub> | CLK to DIO Valid Delay | | 150 | ns | Under Pin Loads* | | t <sub>CDF</sub> | CLK to DIO Entering Float | 10 | 250 | ns | Under Pin Loads* | | t <sub>CDE</sub> | CLK to DIO Enabled from Float | | 150 | ns | Under Pin Loads* | | t <sub>CDH</sub> | CLK to DIO Hold Time | 0 | | ns | Under Pin Loads* | | t <sub>CSOL</sub> | CLK to SYNC Leading Edge Delay | | 120 | ns | Under Pin Loads* | | t <sub>CSOT</sub> | CLK to SYNC Trailing Edge Delay | 10 | 100 | ns | Under Pin Loads* | | t <sub>DC</sub> | DIO Setup Time to Clock | 80 | | ns | Under Pin Loads* | | †DHC | DIO Hold Time from Clock | 0 | | ns | Under Pin Loads* | | t <sub>COL</sub> | CLK to Output Leading Edge | | 150 | ns | Under Pin Loads* | | tсот | CLK to Output Trailing Edge | 0 | 190 | ns | Under Pin Loads* | | t <sub>EW</sub> | ERR. FLG Pulse Width | 200 | | ns | Under Pin Loads* | | tscft | SHIFTCLK to Y - Trailing Edge | 80 | 200 | ns | Under Pin Loads* | A.C. CHARACTERISTICS (Continued) ( $T_A$ = see front page; $V_{CC}$ = 5.0 ± 5%, -10%; $C_L$ = 150pF; unless otherwise noted; \*\* = 7220-5.) | Symbol | Parameter | Min. | Max. | Unit | Test Condition | |-----------------|-------------------------|-----------------------------------------------|------------|------|---------------------------------------------------| | <sup>t</sup> AC | Select Setup to RD↓ | 0 | | ns | | | <sup>t</sup> CA | Select Hold from RD↑ | 0 | | ns | | | tRR | RD Pulse Width | 200 | | ns | | | † <sub>AD</sub> | Data Delay from Address | | 150(200**) | ns | | | t <sub>RD</sub> | Data Delay from RD↓ | | 150(200**) | ns | | | <sup>t</sup> DF | Output Float Delay | 10 | , 100 | ns | , . | | tDC | DACK Setup to RD↓ | 0 | | ns | | | tcp | DACK Hold from RD↑ | 0 | | ns | į | | t <sub>KD</sub> | Data Delay from DACK↓ | | 150(200**) | ns | | | tCYCR | "Read" Cycle Time | (DMA Mode)<br>4t <sub>p</sub> -t <sub>g</sub> | | ns | In non DMA mode. $t_{CYCR}$ Min. = $6t_p$ - $t_g$ | #### WRITE CYCLE (HOST INTERFACE) | Symbol | Parameter | Min. | Max. | Unit | Test Condition | |--------------------|------------------------------------------------|-----------------------------------|------|------|----------------| | t <sub>AC</sub> | Select Setup to WR↓ | 0 | | ns | | | tCA | Select Hold from WR↑ | 0 | | ns | | | tww | WR Pulse Width | 200 | | ns | | | t <sub>DW</sub> | Data Setup to <del>WR</del> ↑ | 200 | | ns | | | two | Data Hold from WR↑ | 0 | | ns | , | | tDC | DACK Setup to WR↓ | 0 | | ns | | | tCD | DACK Hold from WR↑ | 0 | | ns | | | tcycw | "Write" Cycle Time | 4t <sub>P</sub> + t <sub>ww</sub> | | | : | | tca | Request Hold from RD or WR<br>(Non-Burst Mode) | | 200 | ns | | | <sup>†</sup> DEADW | Inactive Time between WR1 and WR1 | 4t <sub>P</sub> | | ns | | | †DEADR | Inactive Time between RD1 and RD1 | 150 | | , | | #### MD7250-MD7230 INTERFACE TIMINGS | Symbol | Parameter | Min. | Max. | Unit | Test Condition | |--------|------------------------------------|------|------------|------|------------------| | tCBL | CLK to Bubble Signal Leading Edge | | 250(275**) | ns | Under Pin Loads* | | tсвт | CLK to Bubble Signal Trailing Edge | | 250(275**) | ns | Under Pin Loads* | #### \*Bubble Pin Loads Shown Below #### **PIN LOADINGS** | Pin Names | Value | Unit | |---------------------------------------------------------------------------------------|-------|------| | $\overline{X+}$ , $\overline{X-}$ , $\overline{Y+}$ , $\overline{Y-}$ | 150 | ρF | | TM.A, TM.B, REP.EN, BOOT.EN,<br>SWAP.EN, BOOT.SW.EN, C/D,<br>ERR.FLG, WAIT, SYNC, DIO | 100 | pF | | DET.ON & SHIFT.CLK | 100 | pF | | BUS.READ | 10 | pF | #### **WAVEFORMS**