# IMS A100 IMS A100M # Cascadable Signal Processor **Engineering Data** #### **FEATURES** Variants for full MIL temperature range (-55°C to +125°C) MIL-STD-883C processing Full 16 bit, 32 stage, transversal filter Fully cascadable with no speed degradation or reduction in dynamic range Coefficients selectable as 4, 8, 12, or 16 bits wide Data throughput to 15.0 MHz High speed microprocessor compatible interface Data input and output through dedicated ports or via the microprocessor interface Fully static high speed CMOS implementation Single +5V ±5% or ±10% power supply variants TTL and CMOS compatibility Less than 2W power dissipation Standard 84-pin PGA or flatpack package #### **APPLICATIONS** Digital FIR filtering High speed adaptive filtering Correlation and Convolution Discrete Fourier Transform Speech processing using Linear Predictive Coding Image processing Waveform synthesis Adaptive and fixed equalizers and echo cancellers Spread spectrum communication Beamforming and beamscanning in sonar and radar Pulse compression High speed fixed point matrix multiplication 42-1442-01 June 1989 #### 3.1 INTRODUCTION The IMS A100 is a high speed, high accuracy 32 stage transversal filter. Its flexible architecture allows it to be used as a 'building block' in a wide range of Digital Signal Processing (DSP) applications. The part is capable of performing high speed DFTs, convolution and correlation, as well as many filtering functions. The input data word length is 16 bits, and coefficients are programmable to be 4, 8, 12 or 16 bits wide; two's complement numerical formats are used for both data and coefficients. The coefficients can be updated asynchronously to the system clock during normal operation, allowing the chip to be used in a variety of adaptive systems. The IMS A100 can also be cascaded to construct longer transversal filters with no additional logic or degradation in speed, whilst preserving a high degree of accuracy. The device is controlled through a standard memory interface, allowing use with any general purpose microprocessor. Data communications can be either through the memory interface, or through dedicated data ports. #### 3.2 DESCRIPTION The IMS A100 is a 32 stage, cascadable, digital transversal filter. The general canonical transversal filter is shown in figure 3.1. An alternative, and functionally equivalent filter is shown in figure 3.2. It is this second realisation that is used in the IMS A100, where the input signal is supplied in parallel to all 32 multipliers, and the delay and summation operations are performed in a distributed manner. Figure 3.1 Canonical transversal filter architecture Figure 3.2 Modified transversal filter architecture Each data sample loaded into the IMS A100 is fed in parallel to all 32 stages. At each stage the current input sample is multiplied by a coefficient stored in memory, and added to the output of the previous stage delayed by one clock cycle. The filter output at time t = kT is given by: $$y(kT) = C(0) \times x(kT) + C(1) \times x((k-1)T) + \dots$$ $$\dots + C(N-1) \times x((k-N+1)T)$$ where x(kT) represents the kth input data sample, and C(0) to C(N-1) are the coefficients for the N stages. While the IMS A100 architecture is designed as a transversal filter it contains many features which allow it to be used in a wide range of signal processing applications, e.g. adaptive filtering, matrix multiplication, discrete Fourier transforms, correlation and convolution. Figure 3.3 shows the users view of the IMS A100. Figure 3.3 IMS A100 Users Model The IMS A100 has four interfaces through which data can be transferred. The memory interface port allows access to the coefficient registers, the configuration and status registers and the data input and output registers for the multiplier accumulator array. Three dedicated ports are also provided, allowing high speed data input and output to the IMS A100 and the cascading of several devices. Typically a microprocessor will configure the IMS A100 via the memory interface, then in a simple system data input and output can be performed through the data input (DIR) and data output (DOL, DOH) registers. Alternatively in a higher performance system data transfer may be performed via the dedicated input and output ports. A typical IMS A100 based system is shown in figure 3.4. Simple high-throughput fixed-configuration systems can be implemented by clocking the configuration information into the IMS A100 from a ROM. The IMS A100 input data word width is 16 bits. The coefficient words can be programmed to be 4, 8, 12, or 16 bits wide. There is a trade off between the coefficient size and the speed of operation. If the coefficient word is $L_C$ bits wide and the clock frequency applied to the IMS A100 is F then the maximum data throughput is $\frac{2KF}{L_C}$ . So, for an IMS A100 operating from a 20.8 MHz clock and using 4-bit coefficients the maximum data throughput is 10.4 MHz, similarly for 16-bit coefficients the throughput is 2.6 MHz. To preserve complete numerical accuracy, no truncation or rounding is performed on the partial products in the multiplier accumulator array. The output of this array is calculated to full precision (36 bits). A programmable barrel shifter is located at the output of this array, which allows one of five 24 bit fields to be selected from the 36 bit result. The selected 24 bits are always correctly rounded and are sign extended before being output. The selection required can be determined from analysis of the coefficients and input data used in a given application. Two banks of coefficients are provided. At any instant one set of coefficients is in use within the multiplier accumulator array, the other set being accessible via the memory interface. Once a new set of coefficients has been loaded, the two coefficient banks can be interchanged by performing a write operation to the 'Bank Swap' bit of a control register. So that devices can be cascaded (eg. to construct longer transversal filters), a 32 stage, 24 bit wide, shift register and 24 bit adder is included on chip. The output of one chip is connected directly to the cascade input of the next. The output of the shift register is added internally to the output of the programmable barrel Figure 3.4 A simple IMS A100 based system shifter to give the final 24 bit output from the chip. To minimise pin count and external buses, the data output and the cascade input ports transfer 24 bit words as a pair of 12 bit words across a 12 bit wide multiplexed interface. As IMS A100s can be cascaded there is a price / performance trade off for most IMS A100 systems. For example, a correlation application could achieve high performance by using a cascade of IMS A100s sufficiently long to hold one of the waveforms being correlated in its coefficient registers and sending the other waveform involved in the correlation along the cascade of IMS A100s. A cheaper and slower solution would be to use a smaller number of IMS A100s and to decompose the single long correlation into a sequence of shorter correlations, the results of which are then summed. #### 3.3 PIN DESIGNATIONS #### System services | Pin | In/out | Function | | |----------|--------|--------------------------|--| | VCC, GND | | Power supply and return | | | CLK | in | Input clock | | | RESET | in | System reset | | | ERROR | out | Numerical overflow error | | | BUSY | out | Bank swap in progress | | ## Synchronous input/output | Pin | In/out | Function | |------------|--------|-----------------------------------------| | GO | in/out | Initiate input/computation/output cycle | | DIN[0-15] | in | Data input port | | DOUT[0-11] | out | Data output port | | CIN[0-11] | in | Cascade input port | | OUTRDY | out | Output data ready | #### Asynchronous input/output | Pin | In/out | Function | |-------------------------|--------|-------------------------------| | D[0-15] | in/out | Memory interface data bus | | ADR[0-6] | in | Memory interface address bus | | CS | in | Memory interface select | | CE | in | Memory interface enable | | $\overline{\mathbf{w}}$ | in | Memory interface write enable | #### **Notes** Signal names are shown with an overbar if they are active low, otherwise they are active high. Pinout details are given in section 3.7 #### 3.3.1 System services System services include all the necessary logic to start up and maintain the IMS A100. #### **Power** Power is supplied to the device via the VCC and GND pins. Several of each are provided to minimise inductance within the package. All supply pins must be connected. The supply must be decoupled close to the chip by at least one 100nF low inductance (e.g. ceramic) capacitor between VCC and GND. Four layer boards are recommended; if two layer boards are used, extra care should be taken in decoupling. Input voltages must not exceed specification with respect to VCC and GND, even during power-up and power-down ramping, otherwise *latchup* can occur. CMOS devices can be permanently damaged by excessive periods of latchup. #### CLK The clock input signal CLK controls the timing of input and output on the three dedicated ports and controls the progress of data through the multiplier accumulator array. #### RESET When the IMS A100 is reset the control logic within the IMS A100 will be reset and the ACR and SCR will be initialised to their default values. Note that neither the internal data path registers nor the coefficient registers are affected by the reset. Resetting the device initialises the SCR to its default setting. So, depending on the setting of SCR before a reset, a reset may also be a device reconfiguration. The sequence of operations required to return the device to a defined state following reconfiguration is described under SCR in the register description. A reset is initiated automatically when power is first applied to the device. This reset will be completed once four cycles of CLK have occured after VCC is valid. Alternatively reset can be initiated by taking RESET low. This reset will be completed after at least two cycles of CLK have occured while RESET is held low. RESET should be held low for at least 200ns. Normal device operation can then continue after RESET is taken high. The reset should be completed before either the synchronous or asynchronous parts of the device are used. #### ERROR If asserted, this pin indicates an error condition has occured, and that the condition has not been cleared. The error condition results from a numerical overflow in either the final adder or in the field selector. To allow this signal to be wire ORed between all the devices in a cascade and hence to be used as an interrupt signal to the host processor, the **ERROR** outputs are open collector. If suitably armed before the error occured the ACR error bits can be read to discriminate the two error sources. The error bits in the ACR and the error condition can be cleared and then the error bits armed to detect further errors by writing values to the ACR. The sequence of values that should be written to the ACR error bits is 0 followed by 1. An error condition can only be cleared if the error bits were suitably armed before the most recent error occured. The ACR error bits may not observe an error occuring between clearing and arming the error bits. So, when clearing an error and arming the error bits precautions should be taken to ensure that no new error occurs. For example, first prevent the IMS A100 from initiating computation on new data; second wait for any results pending to be output; then clear and rearm. The ACR error bits will observe any error occuring after they are armed. Thus, if an error occured before the ACR error bits were armed it may be necessary to arm the error and then force an error before proceeding to clear the error (as described above). Following power up the contents of the multiplier accumulator array and cascade path are indeterminate. As this indeterminate data flushes through a system of one or more IMS A100s errors are likely to occur. Similarly, altering the device configuration defined by the SCR is likely to result in errors. The sequence of operations required to return the device to a defined state following reconfiguration is described under SCR in the register description section of this specification. #### **BUSY** When high this pin indicates that an exchange of data between the Current and Update Coefficient Registers is in progress. Under certain conditions the duration of BUSY may be vanishingly small. BUSY will be active if the bank swap is caused by setting ACR[0] to request a single bank swap or when SCR[2] is set selecting Continuous Swap mode. The detailed behaviour is described in the bankswap timing diagrams. #### 3.3.2 Synchronous input/output #### GO The GO signal initiates a cycle of data input, computation and output. An IMS A100 configured as a slave will monitor the GO signal on the rising edge of CLK one cycle before it is ready to accept more data and on every rising edge thereafter until GO is found to be high. If GO is high then data input will occur on the next rising edge of CLK. If GO is low when it is sampled no new data input will occur. In a cascade of IMS A100s one IMS A100 may be configured as a master. The master IMS A100 will drive its GO pin high after data has been written into its Data Input Register indicating that new data is available and that the slave IMS A100s in the casacade should start an input, computation, output cycle. When the GO signal goes low new data can be written to the IMS A100s. Typically a host processor will write simultaneously to the Data Input Registers of all the IMS A100s in the cascade. The host will then monitor the GO signal before writing new data to the cascade. #### DIN[0-15] This 16 bit wide data input port allows high speed data input to the IMS A100. The timing of this input is controlled by the CLK and GO signals. In a cascade of IMS A100s the 16 bit wide input data path and the CLK and GO signals will be bussed to all devices. #### DOUT[0-11] This 12 bit data port outputs the result from the IMS A100. The 24 bit result is multiplexed through this port as two 12 bit words, the least significant word being output first. The most significant word is output second and remains on the data pins until a new data output sequence is about to start. The **OUTRDY** signal can be used to latch these words into external circuitry. In a cascade of IMS A100s the **DOUT** pins of one device connect to the **CIN** pins of the next device in the cascade. #### CIN[0-11] The Cascade Input allows multiple IMS A100s to be cascaded. A 24 bit word is input as two 12 bit words the least significant word being input first. The 24 bit word is delayed by a shift register and summed with the output of the multiplier accumulator array. The delay from a word being input on the cascade input to that word affecting the data output is 32 data input cycles. In a typical IMS A100 based system the cascade input of each device will be connected to the data output DOUT[0-11] of the previous IMS A100 in the cascade. The Cascade Input of the first device in the cascade will normally be connected to ground. # **OUTRDY** The output ready signal **OUTRDY** goes low just after the least significant data output word is available on the **DOUT** pins and goes high just after the most significant word is available. The rising edge of **OUTRDY** also indicates that the Data Output registers (DOL, DOH) contain the new result word. Thus the **OUTRDY** signal can either be used to latch the output of the IMS A100 into external logic or to indicate that output of the IMS A100 can be read through the memory interface from the Data Output registers. #### 3.3.3 Asynchronous input/output #### CS This pin selects the chip; if chip select $\overline{CS}$ is low an access to the memory interface will be enabled. This signal is usually asserted by the host processors' address decoder at the beginning of a memory cycle. ## CE The chip enable pin. The memory interface on the IMS A100 appears to the system controlling it as 128 words of static RAM. The chip enable $\overline{CE}$ signal is similar in operation to the chip enable signal found on static RAMs. When $\overline{CE}$ is high the chip select, write enable and the address inputs are ignored and the memory interface data bus is tri-state. When chip enable is low a single read or write access is made to one of the registers within the IMS A100. Accesses to the memory interface can occur completely asynchronously to operations on the data in, cascade in and data output ports DIN[0-15], CIN[0-11] and DOUT[0-11]. # $\overline{\mathbf{w}}$ The write enable pin indicates whether the access to the IMS A100 memory interface is to be a write or a read. If $\overline{\mathbf{W}}$ is low a write access is indicated. #### ADR[0-6] The seven bit address bus comprises pins ADR[0-6]. The seven bit binary value applied to the address inputs of the IMS A100 indicates which register is to be accessed. #### D[0-15] During a write to the memory interface a 16 bit word is applied to data bus pins D[0-15]. This word will be latched on the rising edge of chip enable $\overline{CE}$ at the end of the cycle. During a read cycle the contents of the location accessed are placed on the data pins. When $\overline{CE}$ is high the data signals are tri-state. #### 3.4 REGISTER DESCRIPTION The memory map shown below indicates the primary addresses for each register. All locations between decimal addresses 64 and 75 inclusive are uniquely decoded. This group of registers is shadowed at other locations up to the 128 word boundary. The effect of reading and writing to areas in the memory map other than those shown in the table is undefined. If the user wishes to initialise the device from a ROM addressed by a clocked counter, one of the following options applies: - 1 Restrict the counter to count only from 0 to 68; this avoids writing to the data registers as well as the shadow locations. - 2 Count down from 127 to zero. The initialization at the lower addresses will override spurious ones at the higher shadowed addresses. # 3.4.1 Memory map † | Register | Address<br>decimal | Address<br>hex | Function | | |-----------|--------------------|----------------|-----------------------------------------------|--| | CCR[0-31] | 32–63 | 20–3F | Current Coefficient Registers | | | UCR[0-31] | 0–31 | 00–1F | Update Coefficient Registers | | | SCR | 64 | 40 | Static Control Register | | | | 65 | 41 | Unused location | | | ACR | 66 | 42 | 2 Active Control Register | | | | 67 | 43 | Unused location | | | TCR | 68 | 44 | Test Control Register | | | DIR | 72 | 48 | Data Input Register | | | DOL | 74 | 4A | Data Output Register (Least Significant Word) | | | DOH | 75 | 4B | Data Output Register (Most Significant Word) | | <sup>†</sup> All other locations accessible via the memory interface of the IMS A100 are reserved. #### 3.4.2 Registers #### CCR[0-31] The Current Coefficient Registers contain the coefficients currently being used by the multiplier accumlator array. CCR[0] (decimal address 32) corresponds to the coefficient register of the multiplier accumlator nearest the output of the IMS A100: i.e. this location is equivalent to C(0) in figure 3.2. Similarly CCR[31] (decimal address 63) corresponds to C(31). The Current Coefficient Registers can be read from at any time and can be written to provided that no data processing is taking place. The effect of writing to the Current Coefficient Registers while data is being processed is undefined. #### UCR[0-31] The Update Coefficient Registers are equivalent to the Current Coefficient Registers, with the exception that the values in the Update Coefficient Registers are not currently in use within the multiplier accumilator array and can therefore be written to at any time. A bank swap operation is equivalent to an exchange of data between the Update Coefficient Registers and the Current Coefficient Registers. Figure 3.5 IMS A100 memory map ## SCR The Static Control Register contains the control bits which configure the IMS A100 and are unlikely to need updating after their initial configuration. The contents of the Static Control Register are not affected by the IMS A100 and can be read at any time. Reconfiguring the SCR may result in indeterminate data values within the IMS A100 system. These values may in turn result in errors. After reconfiguring the SCR the following sequence should be followed to return the IMS A100 system to a defined, error free condition: - 1 Arm error bits in ACR. - 2 After SCR has been reconfigured GO should be held low for 20 cycles of CLK. - 3 A series of suitable data values should then be flushed through the IMS A100 system. - 4 Any errors generated should then be cleared. - 5 The IMS A100 system is then ready to commence normal operation. #### ACR The Active Control Register contains status and control bits which are likely to be accessed during normal operation of the IMS A100; i.e. when handling error conditions and when requesting single coefficient bank swaps. #### **TCR** The Test Control Register is used for test purposes. One of the test modes provides access to the least significant part of the multiplier accumulator array output. #### DIR The Data Input Register. The IMS A100 can be configured to either take its input data from the DIN pins or from the Data Input Register. If the IMS A100 is configured as the master of a cascade of IMS A100s the GO signal will be driven in response to writing data into the Data Input Register. In a small IMS A100 based system the Data Input Registers of all the devices in the cascade will normally be mapped into the same location within the address space of the processor controlling the cascade. Thus a single write operation can write data to all devices, the master IMS A100 generating the GO signal for the slaves. The Data Input Register is write only. #### DOL The least significant word of the Data Output Register. The output data from the IMS A100 is available from both the **DOUT[0–11]** pins and from the Data Output Registers. The value held in the Data Output Registers is the 24 bit output word, sign extended to 32 bits. DOL contains the least significant 16 bits of the 24 bit result: the register is read only. #### DOH The most significant word of the Data Output Register. The DOH register contains the most significant 8 bits of the 24 bit output word generated by the IMS A100. The most significant 8 bits of DOH are the sign extension of the output word. DOH is read only. The remainder of this section describes the register details bit by bit. Each section commences with the name of the register with the bit number(s) followed by the default value, in the general format: Name REGISTER[MSB-LSB] Default: MSB LSB The least significant bit of a register is bit 0. † in the tables indicates the default state of the register bit(s). #### 3.4.3 Static control register #### Fast Output SCR[10] Default: 0 The Fast Output bit controls the way in which the 24 bit output of the IMS A100 is multiplexed across the 12 bit wide **DOUT** port. The interval between data output cycles is the same for both Normal and Fast output modes. The difference between the modes is the time division between the least and most significant words. In fast output mode the least significant 12 bit word is available for the minimum period possible, thus allowing the most significant word to be output at the earliest possible instant. In normal output mode the least significant word is available for the same length of time as the most significant word (unless the duration of the most significant word is extended by idle cycles). The timing constraints on data output in Normal mode are significantly simpler than those in Fast mode. Fast mode should be considered a special mode which is only used where the early availability of the output words is important, e.g. an adaptive system where the filter coefficients are being modified in response to the output data. All devices in a cascade of IMS A100s should be configured for the same output mode. The Fast Output bit should not be altered during data processing. If it is altered the data output of the cascade will be undefined until new input data has flushed through all stages of the cascade. If the coefficient size is 4 bits there is no difference between the fast and normal modes. | SCR[10] | Output mode | |---------|-------------| | 0 | Normal † | | 1 | Fast | **Coefficient Size** SCR[9-8] Default: 1 1 Defines size of coefficient used, in terms of word width. This also determines the minimum interval between data input cycles and thus the data throughput of the IMS A100. The Coefficient Size bits should not be altered during data processing. If they are altered the data output of the cascade will be undefined until new input data has flushed through all stages of the cascade. In each mode the coefficient data is the least significant bits of the 16 bit word; e.g. in 4 bit mode, a two's complement number should be programmed into bits 0-3 of the 16 bit register. The remaining bits 4-15 are ignored. | SCR[9-8] | Coefficient size | Data input interval | | | |----------|------------------|---------------------|--|--| | 0 0 | 4 bits | 2 cycles | | | | 0 1 | 8 bits | 4 cycles | | | | 10 | 12 bits | 6 cycles | | | | 11 | 16 bits | 8 cycles † | | | Reserved SCR[7-6] Default: 0 0 These locations are reserved. The user should write 0,0 to these locations to maintain compatability with future products. The value read from this location is undefined. Reserved SCR[3] Default: 0 This location is reserved. The user should write 0 to this location to maintain compatability with future products. The value read from this location is undefined. **Output Word Selection** SCR[5-4] Default: 1 0 These bits determine the 24 bit wide field selected from the 36 bit wide output of the multiplier accumulator array (bit positions numbered 0 to 35). The word selected will be rounded and sign extended before being output. Note that ranges '10' and '11' imply sign extension of the result. The Output Word Selection bits should not be altered during data processing. If they are altered the data output of the cascade will be undefined until new input data has flushed through all stages of the cascade. | SCR[5-4] | Field | |----------|-----------| | 0.0 | [7–30] | | 01 | [11–34] | | 10 | [15–38] † | | 11 | [20–43] | Continuous Swap SCR[2] Default: 0 The Continuous Swap bit selects whether the two banks of coefficient registers are automatically exchanged after each data input and computation cycle or if individual bank swaps occur under the direction of the Bank Swap bit in the Active Control Register, ACR[0]. SCR[2] should not be set if a bankswap has been requested (by setting ACR[0]) and is still pending. | SCR[2] | Swap Mode | |--------|------------------------------------| | 0 | Swap on asserting ACR[0] † | | 1 | Swap after end of each input cycle | Input Data Source SCR[1] Default: 0 The data source for the multiplier accumulator array can come from one of two sources, selected by SCR[1]. Data can either be input from the **DIN** port or it can be written into the Data Input Register via the memory interface. See also the following section. | SCR[1] | Data Source | |--------|------------------------| | 0 | From <b>DIN</b> port † | | 1 | From DIR | Master not Slave SCR[0] Default: 0 The Master not Slave bit selects whether the IMS A100 samples the GO input to determine the start of a data input cycle (slave mode), or drives the GO pin when data is written to the DIR (master mode). If input data is supplied through the DIR one IMS A100 in the cascade should be configured as a master. If data is supplied to the DIN port by an external data source all the IMS A100s in the cascade should be configured as slaves and GO should be driven by an external system. Note that an illegal mode results if SCR[1] is 0 and SCR[0] is 1; i.e. a master cannot obtain data from the DIN port. | SCR[0] | Mode | | | |--------|---------|--|--| | 0 | Slave † | | | | 1 | Master | | | #### 3.4.4 Active control register # Cascade Adder Overflow ACR[2] Default: 0 If previously armed this status bit will be set if the addition of the 24 bit words output by the 24 from 36 bit selector (on the output of the multiply accumulator array) and the cascade shift register causes an arithmetic overflow. The **ERROR** pin will be driven low while this or any other error condition is active. This error bit and the error condition can be cleared by writing a zero to ACR[2], provided the data in the adder is no longer in error. After clearing this error bit the error bit should be armed (by writing a one to ACR[2]) to ensure that any future error is detected. See **ERROR** section. Selector Overflow ACR[1] Default: 0 If previously armed this status bit will be set if the 24 bit output range of the selector does not include all the significant binary digits in the 36 bit result generated by the multiply accumulator array. The **ERROR** pin will be driven low while this or any other error condition is active. This error bit and the error condition can be cleared by writing a zero to ACR[1]. After clearing this error bit the error bit should be armed (by writing a one to ACR[1]) to ensure that any future error is detected. See **ERROR** section. Initiate Bank Swap ACR[0] Default: 0 Writing a one into this control bit requests an exchange of data between the Current and Update Coefficient Registers. The bank swap will occur as soon as the current computation cycle is completed, or on the next clock cycle if the IMS A100 is idle. This control bit is cleared to zero by the IMS A100 when the bank swap is complete. No access should be made to either set of coefficient registers while a bank swap is in progress. ACR[0] should not be set if SCR[2] is already set. For a detailed description of the behaviour see the bankswap and coefficient access timing diagrams. #### 3.4.5 Test control register #### Examine Full Output Word TCR[2] Default: 0 This bit overrides the output word selection normally made by bits SCR[5-4]. The output word selection determines the 24 bit wide field selected from the 36 bit wide output of the multiply accumulator array (bit positions numbered 0 to 35). When TCR[2] is set to '1' the output word selection is bits '-1' to 22, where bit '-1' is set to zero. The output word selection should not be altered during data processing. If altered the data output of the cascade will be undefined until new input data has flushed through all stages of the cascade. | TCR[2] | Field | |--------|-------------------| | 0 | Set by SCR[5-4] † | | 1 | [-1-22] | Reserved TCR[1] Default: 0 This location is reserved for INMOS test purposes. For normal operation the user should write 0 to this location. Reserved TCR[0] Default: 0 This location is reserved for INMOS test purposes. For normal operation the user should write 0 to this location. #### 3.5 DEVICE APPLICATIONS The IMS A100 can be used in a variety of different applications requiring high performance computation. Some of these are described below, and are covered in detail in the IMS A100 Application Note series, available from INMOS. #### 3.5.1 Filtering and adaptive filtering The IMS A100 device can be used to implement high speed FIR and IIR digital filters. The maximum sampling frequency of the input signal ranges between 2.125MHz and 15MHz, depending on the coefficient word length and speed variant that has been selected. The continuous bank swap mode allows a single device to filter complex (I & Q) data streams. High speed random access coefficient registers enable high performance adaptive filters and equalisers to be realised with minimal complexity. The cascadability of the device enables FIRs of greater than 32 stages to be constructed, with no degradation in data throughput. #### 3.5.2 Convolution and correlation The IMS A100 is the first single-chip digital correlator capable of highly accurate computation of correlation and convolution functions (16-bit coefficients, 16-bit data and 36-bit accumulation). These functions have applications in matched filtering, noise reduction and pulse compression in communication, radar and sonar systems. For correlations and convolutions involving a large number of data points, devices can be cascaded to several thousand stages with careful design. Alternatively, it is possible to use algorithms which allow decomposition of long correlation and convolutions into several smaller ones, which can then be carried out by a single or smaller number of devices. #### 3.5.3 Matrix multiplication The architecture of the IMS A100 allows very high speed fixed point matrix multiplication. In this application the columns of the multiplier matrix are circulated as inputs to the chip while the coefficients are programmed in a suitable manner with the elements of the multiplicant matrix. Larger matrices can be handled by either cascading several chips or by decomposing the matrices into smaller ones. #### 3.5.4 Fourier transforms Two algorithms, namely the Prime Number Transform (PNT) and the Chirp-Z Transform (CZT), can be used to perform high speed Fourier transforms using IMS A100s. The Fourier transform of long data sequences can be evaluated either by using cascaded IMS A100s or by using decomposition algorithms to convert a long transform into a number of short transforms (e.g. <32 points). These short transforms can then be carried out using the IMS A100s and a host processor. The speed of transform can be traded off against the number of chips employed. Any microprocessor with a standard memory interface could be used to handle intermediate results and to control the overall system. Two IMS A100s can be used to perform a transform of about 1000 points in around 1 ms to 2 ms using look-up ROMs for address generation and high speed DSP controllers, or 5 ms to 10 ms using a microprocessor as the controller. More IMS A100s can be used if higher performance is required. # 3.5.5 Waveform synthesis The programmability of this digital transversal filter allows the IMS A100 to be used for flexible waveform generation and synthesis, by exploiting the ability to change coefficients randomly, quickly and simply. Such a configuration could be attractive for PC based synthesisers, as the chip can generate very accurate high bandwidth signals. #### 3.5.6 General purpose accelerator By attaching one or more IMS A100s to any computer with DMA capability, a useful accelerator can be constructed, capable of handling all of the above applications without reconfiguration. The cascadability of the device enables users to add IMS A100s as required for extra processing performance, with minimal impact on the driving software. #### 3.6 ELECTRICAL SPECIFICATION The IMS A100 is available in several speed, package and temperature variants (see section 3.9 – Ordering details) and the electrical characteristics of each are described in this section. When no variant is identified the information refers to all variants. #### 3.6.1 DC electrical characteristics #### Absolute maximum ratings | Symbol | Parameter | Min. | Max. | Units | Notes (1) | |--------|----------------------------------|------|---------|-------|-----------| | vcc | DC supply voltage | 0 | 7.0 | V | 2,3 | | VI, VO | Voltage on input and output pins | -1.0 | VCC+0.5 | V | 2,3 | | TS | Storage temperature | -65 | 150 | ۰c | 2 | | TA | Temperature under bias | -55 | 125 | °C | 2 | | PDmax | Power dissipation | | 2.0 | w | 2 | - 1 All voltages are with respect to GND. - 2 This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the operating sections of this specification is not implied. Stresses greater than those listed may cause permanent damage to the device. Exposure to absolute maximum rating conditions for extended periods may affect reliability. - 3 This device contains circuitry to protect the inputs against damage caused by high static voltages or electrical fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than the absolute maximum rated voltages to this high impedence circuit. Unused inputs should be tied to an appropriate logic level such as VCC or GND. # DC operating conditions | Symbol | Parameter | Min. | Nom. | Max. | Units | Notes (1) | |--------|------------------------------------|------|------|---------|-------|-----------| | VCC | DC supply voltage | 4.5 | | 5.5 | ٧ | 4 | | vcc | | 4.75 | | 5.25 | ٧ | 5,6,7 | | VIH | Input Logic '1' Voltage CLK | 4.0 | ļ | VCC+0.5 | V | 2 | | | Input Logic '1' Voltage RESET | 2.4 | | VCC+0.5 | ٧ | 2 | | | Input Logic '1' Voltage other pins | 2.0 | [ | VCC+0.5 | V | 2 | | VIL | Input Logic '0' Voltage CLK | -0.5 | } | 0.5 | V | 2 | | | Input Logic '0' Voltage RESET | -0.5 | 1 | 0.8 | V | 2 | | | Input Logic '0' Voltage other pins | -0.5 | { | 0.8 | V | 2 | | TA | Ambient Operating Temperature | 0 | | 70 | ۰c | 3,4,7 | | TA | | -55 | | 125 | •c | 3,5,6 | - 1 All voltages are with respect to GND. All GND pins must be connected to GND. - 2 Input signal transients up to 10 ns wide, are permitted in the voltage ranges (GND 0.5 V) to (GND 1.0 V) and VCC + 0.5 V to VCC + 1.0 V. - 3 400 linear ft/min transverse air flow. - 4 IMS A100-G21S, IMS A100-Q21S. - 5 IMS A100-G21M, IMS A100-Q21M. - 6 IMS A100-G17M. - 7 IMS A100-G30S. #### DC characteristics | Symbol | Parameter | Min. | Max. | Units | Notes (1,2) | |--------|--------------------------------------------------------------------------------------------------|------|------|-------|-------------| | VOH | Output Logic '1' Voltage | 2.4 | vcc | V | 4 | | VOL | Output Logic '0' Voltage | 0 | 0.4 | V | 5 | | II | Input current @ GND <vi<vcc< td=""><td></td><td>±10</td><td>μΑ</td><td></td></vi<vcc<> | | ±10 | μΑ | | | IOZ | Tristate output current @ GND <vi<vcc< td=""><td></td><td>±10</td><td>μΑ</td><td></td></vi<vcc<> | | ±10 | μΑ | | | ICC | Average power supply current | | 360 | mA | 3 | #### **Notes** - 1 All voltages are with respect to GND. All GND pins must be connected to GND. - 2 Parameters measured over variants full voltage and temperature operating range. - 3 Power dissipation is application dependent and varies with output loading. The maximum given here is for worst case data patterns and activity on all interfaces, with no DC load on outputs. - 4 OUTRDY, DOUT: IOut $\leq$ -4.4 mA; ERROR is open collector; other outputs: IOut $\leq$ -5.5 mA. - 5 OUTRDY, DOUT: IOut $\leq$ 4.4 mA; ERROR: IOut $\leq$ 5.5 mA; other outputs: IOut $\leq$ 5.5 mA. #### Capacitance | Pin | Тур. | Units | Notes | |----------------|------|-------|-------| | CLK | 12 | pF | 1,2 | | All other pins | 5 | рF | 1,2 | - 1 This parameter is supplied for engineering guidance and is not guaranteed. - 2 TA=25°C, F=1 MHz. # 3.6.2 AC timing characteristics # **AC** test conditions # Output loads (except output turn-off tests) | Pin | Device mode | Load | Unit | |-------------------|---------------|------|------| | GO | Master | 20 | pF | | DOUT, OUTRDY | Fast output | 15 | рF | | DOUT, OUTRDY | Normal output | 30 | рF | | All other outputs | All modes | 30 | рF | # Output load (output turn-off tests) # Timing reference levels | Pin | Reference levels | Notes | |---------|---------------------------------------------------|-------| | INPUTS | 0.8V, 2.0V | 1 | | CLK | 0.5V, 4.0V | | | OUTPUTS | 0.4V, 2.4V | 2,3 | | OUTPUTS | ±100mV change from previous steady output voltage | 4 | - 1 Except CLK. - 2 Output continuously driven. - 3 Timings are tested using VOL=0.8V and with a suitable allowance for the time taken for the output to fall from 0.8V to 0.4V. - 4 Output turn-off tests. # Clock | Symbol | Parameter | Min. | Max. | Units | Notes | |--------|------------------------|------|------|-------|-------| | t CHCL | Clock pulse width high | 19 | | ns | 2 | | t CHCL | | 24 | | ns | 3 | | t CHCL | | 13 | | ns | 4 | | tclch | Clock pulse width low | 19 | | ns | 2 | | tclch | | 24 | | ns | 3 | | tclch | | 13 | | ns | 4 | | t снсн | Clock period | 48 | | ns | 2 | | t снсн | | 58 | 1 | ns | 3 | | t chch | | 33 | 1 | ns | 4 | | tr | Clock rise time | 0 | 50 | ns | 1 | | tF | Clock fall time | 0 | 50 | ns | 1 | - 1 Clock input transitions should be monotonic between the input thresholds of 0.5 V and 4.0 V. - 2 IMS A100-G21S, IMS A100-Q21S, IMS A100-G21M, IMS A100-Q21M. - 3 IMS A100-G17M - 4 IMS A100-G30S # Memory interface read cycle | Symbol | Parameter | Min. | Max. | Units | Notes | |--------------|-----------------------|------|------|-------|-------| | t ELEH | CE pulse width low | 60 | | ns | | | t EHEL | CE pulse width high | 50 | | ns | | | t SLEL | CS setup time | 15 | | ns | | | t ehsx | CS hold time | 5 | | ns | | | t AVEL | Address setup time | 15 | | ns | | | t EHAX | Address hold time | 5 | | ns | | | t WHEL | Read Command setup | 15 | | ns | | | t ehwx | Read Command hold | 5 | | ns | ł | | telax | Output turn on delay | 0 | | ns | ] | | t ELQV | Read data access | | 60 | ns | | | t e hox | Read data hold | 0 | | ns | | | <b>TEHQZ</b> | Output turn off delay | | 25 | ns | | # Memory interface write cycle | Symbol | Parameter | Min. | Max. | Units | Notes | |--------|---------------------|------|------|-------|-------| | t ELEH | CE pulse width low | 50 | | ns | | | TEHEL | CE pulse width high | 50 | | ns | | | t SLEL | CS setup time | 15 | | ns | | | t ehsx | CS hold time | 5 | | ns | | | t AVEL | Address setup time | 15 | 1 | ns | | | t EHAX | Address hold time | 5 | | ns | | | t WLEL | Write Command setup | 15 | } | ns | | | t EHWX | Write Command hold | 5 | } | ns | | | t DVEH | Write data setup | 45 | 1 | ns | | | t ehdx | Write data hold | 5 | | ns | | #### Static read accesses to DOL and DOH registers Certain applications require to read results from the IMS A100 at high speeds. To ensure full system performance it may be necessary to read results from the DOL and DOH registers using a continuous 'static' access rather than using the normal clocked access. During static access the $\overline{\textbf{CE}}$ signal is held low continuously. Under this condition it is possible to monitor either DOL or DOH continuously to observe new output words as they become available or alternatively to switch between DOL and DOH without the restriction of having to sequence $\overline{\textbf{CE}}$ . | Symbol | Parameter | Min | Max | Units | Notes | |---------------|--------------------------------|-----|------|-------|-------| | tavov | Address access time | | 75 | ns | 1 | | tchav | Data input access time | i | 7+75 | ns | 2 | | <b>t</b> ELQV | CE access time | | 60 | ns | 3 | | taxox | Data hold after address change | 0 | | ns | ĺ | | tchax | Data hold after new data input | 7+0 | | ns | 2 | | <b>TEHQX</b> | Data hold after end of read | 0 | | ns | | #### Notes - 1 The address access time is specified for address transitions between decimal 74 (DOL register) and decimal 75 (DOH register) only. - 2 The parameter 7 describes the time taken from the input of a data word to that data word first affecting the most significant word (MSW) output. This is the time at which the DOL and DOH registers are updated. The duration of $\tau$ depends on the coefficient size selected and whether fast or normal output is selected. | Coefficients | Output mode | 7 time | |--------------|-------------|---------------| | 4 bit | Fast | 8 CLK cycles | | 8 bit | [ | 10 CLK cycles | | 12 bit | | 12 CLK cycles | | 16 bit | | 14 CLK cycles | | 4 bit | Normal | Not defined | | 8 bit | | 11 CLK cycles | | 12 bit | | 14 CLK cycles | | 16 bit | | 17 CLK cycles | - N.B. The data value read from either DOL or DOH will change as new results are computed by the device. - 3 This parameter is the normal read access time for reading any register through the microprocessor interface. In the special case of performing reads from only DOL and DOH any number of reads from these registers can be made with $\overline{CE}$ held low continuously. It is required that a static access (as described above) should commence like a normal clocked, random, read access to either DOL or DOH. That is ADDRESS, $\overline{CS}$ and $\overline{W}$ should be established with setup times to $\overline{CE}$ specified for a normal read access. During a DOL/DOH static access sequence accesses to locations other than DOL and DOH are undefined. Typical sequence — 8 bit coefficients, normal output - 1 The minimum period between sampling the GO input is four clock cycles for 8 bit coefficients, see the table below for the other cases. - 2 After the minimum period described in note 1 has elapsed GO is sampled on every rising edge of CLK until GO is high. - 3 The delay from an output being initiated by GO to the output completing its previous output sequence and starting the new output sequence is 8 clock cycles for 8 bit coefficients, see the table below for the other cases. - 4 The least significant word is available at the output across one complete CLK cycle for the 8 bit coefficient, normal output case, see the table below for the other cases. - 5 The most significant word is available for the minimum period described in note 4, but will be extended by a clock cycle for each additional idle cycle inserted between data inputs. | Coefficients | Min. Output Period | Delay To Output | Min. LSW Output Duration | |--------------|--------------------|-----------------|-----------------------------| | | note 1 | note 3 | notes 4 and 5 | | 4 bit | 2 CLK cycles | 6 CLK cycles | Undefined, no normal output | | 8 bit | 4 CLK cycles | 8 CLK cycles | 1 CLK cycle | | 12 bit | 6 CLK cycles | 10 CLK cycles | 2 CLK cycles | | 16 bit | 8 CLK cycles | 12 CLK cycles | 3 CLK cycles | # Typical sequence — 8 bit coefficients, fast output - 1 The minimum period between sampling the GO input is four clock cycles for 8 bit coefficients, see the table below for the other cases. - 2 After the minimum period described in note 1 has elapsed GO is sampled on every rising edge of CLK until GO is high. - 3 The delay from an output being initiated by GO to the output completing its previous output sequence and starting the new output sequence is 8 clock cycles for 8 bit coefficients, see the table below for the other cases. | Coefficients | Min. Output Period | Delay To Output | |--------------|--------------------|-----------------| | | note 1 | note 3 | | 4 bit | 2 CLK cycles | 6 CLK cycles | | 8 bit | 4 CLK cycles | 8 CLK cycles | | 12 bit | 6 CLK cycles | 10 CLK cycles | | 16 bit | 8 CLK cycles | 12 CLK cycles | # Typical sequence — 4 bit coefficients - 1 The minimum period between sampling the GO input is two clock cycles for 4 bit coefficients, see the table below for the other cases. - 2 After the minimum period described in note 1 has elapsed GO is sampled on every rising edge of CLK until GO is high. - 3 The delay from an input being initiated by GO to the output completing its previous output sequence and starting the new output sequence is 6 clock cycles for 4 bit coefficients, see the table below for the other cases. | Coefficients | Min. Output Period | Delay To Output | |--------------|--------------------|-----------------| | 1 | note 1 | note 3 | | 4 bit | 2 CLK cycles | 6 CLK cycles | | 8 bit | 4 CLK cycles | 8 CLK cycles | | 12 bit | 6 CLK cycles | 10 CLK cycles | | 16 bit | 8 CLK cycles | 12 CLK cycles | # Normal output timing — 8 bit coefficient case shown | Symbol | Parameter | Min. | Max. | Units | Notes | |--------|----------------------------------|------|------|-------|-------| | tchav | CLK high to DOUT valid delay | | 36 | ns | 3 | | t CHQV | | | 25 | ns | 5 | | tchav | | | 40 | ns | 4 | | t chax | DOUT hold time after CLK high | 2 | 1 | ns | | | t QVRL | DOUT to OUTRDY low lead | 15 | | ns | 3,4 | | t QVRL | | 10 | l | ns | 5 | | t RLQX | DOUT hold time after OUTRDY low | 10 | | ns | 1 | | tovrh | DOUT to OUTRDY high lead | 15 | | ns | 3,4 | | tovrh | | 10 | | ns | 5 | | t RHQX | DOUT hold time after OUTRDY high | 10 | | ns | 1,2 | | TIME1 | LSW output duration | 1 | 3 | tснсн | 1 | | TIME2 | MSW output duration | 1 | 3 | tchch | 1,2 | | t DVCL | CASIN setup time to CLK low | 10 | | ns | 3,5 | | t DVCL | | 14 | | ns | 4 | | tCLDX | CASIN hold time from CLK low | 10 | | ns | | - 1 This parameter is determined by the coefficient size in use. The minimum value given is correct for 8 bit coefficients. This parameter is extended by 1 (or 2) periods of CLK if 12 (or 16) bit coefficients are used. This mode of operation is not defined if 4 bit coefficients are used. - 2 These parameters are extended by one tCHCH for each idle cycle inserted between data input sequences. - 3 IMS A100-G21S, IMS A100-Q21S, IMS A100-G21M, IMS A100-Q21M. - 4 IMS A100-G17M. - 5 IMS A100-G30S. #### Fast output timing — 4 bit coefficient case shown | Symbol | Parameter | Min. | Max. | Units | Notes | |--------|----------------------------------|------|------|-------|-------| | tchQv | CLK high to DOUT valid delay | | 36 | ns | 1,3 | | tchav | | ) | 22 | ns | 1,5 | | tchov | | | 40 | ns | 1,4 | | tchax | DOUT hold time after CLK | 2 | | ns | 2 | | tavaL | DOUT to OUTRDY low lead | 5 | | ns | 1,6 | | t RLQX | DOUT hold time after OUTRDY low | 10 | | ns | 6 | | tovrh | DOUT to OUTRDY high lead | 5 | | ns | 1,6 | | t RHQX | DOUT hold time after OUTRDY high | 10 | | ns | 2,6 | | tovch | CASIN setup time to CLK high | 10 | | ns | 3,5 | | tovch | | 14 | | ns | 4 | | tchdx | CASIN hold time to CLK high | 0 | | ns | | - 1 These parameters assume that each DOUT signal is loaded with a maximum of 15 pF. - 2 t CHOX and t RHOX for the MSW are shown here for the case where 4 bit coefficients are being used. In the other cases (8, 12 and 16 bit coefficients) the MSW is available for an additional 2, 4 or 6 CLK periods. In all cases the MSW will be available for an additional period of CLK for each idle cycle inserted between data input sequences. - 3 IMS A100-G21S, IMS A100-Q21S, IMS A100-G21M, IMS A100-Q21M. - 4 IMS A100-G17M. - 5 IMS A100-G30S. - 6 The OUTRDY signal should not be used in this mode using the IMS A100-G30S variant at clock frequencies above 20.8 MHz. # External GO and data input timing | Symbol | Parameter | Min. | Max. | Units | Notes | |--------|----------------|------|------|-------|-------| | t GHCH | GO setup time | 10 | | ns | | | tcHGX | GO hold time | 5 | Ì | ns | | | tovch | DIN setup time | 30 | | ns | 1 | | t DVCH | | 17 | ] | ns | 2 | | t CHDX | DIN hold time | 5 | 1 | ns | | - 1 IMS A100-G21S, IMS A100-Q21S, IMS A100-G21M, IMS A100-Q21M, IMS A100-G17M. - 2 IMS A100-G30S. # Master generated GO | Symbol | Parameter | Min. | Max. | Units | Notes | |--------|-------------------------------|------|------|-------|-------| | t ehgh | Write to DIR to GO high delay | 25 | | ns | 1,4 | | t GHCH | GO high before GO sampled | 10 | | ns | 2,4 | | t GLEL | GO low to write to DIR | 0 | | ns | 4 | | t GLCH | GO low before GO next sampled | 10 | | ns | 2,4 | - 1 The maximum delay from a write to the DIR to GO going high is 2 \* tchch + 50 ns. - 2 This parameter assumes the capacitive load on GO is less than 20 pF. GO is specified so that one master IMS A100 can drive three slave IMS A100s without buffering. - 3 Accesses can be made through the external memory interface to any register other than DIR. - 4 This mode should not be used with the IMS A100-G30S variant at clock frequencies above 20.8 MHz. #### Bankswap timing | Symbol | Parameter | Min. | Max. | Units | Notes | |--------|--------------------------------|------|------|-------|-------| | t EHBH | ACR[0] set to BUSY high delay | | 55 | ns | 4 | | t CHBL | BUSY hold after bankswap | | 50 | ns | 4 | | tcheh | ACR[0]=0 hold after last input | 20 | } | ns | 3,4 | | t EHCH | ACR[0]=1 setup to next input | 10 | Ì | ns | 3,4 | #### Notes - 1 The activity on $\overline{\text{CE}}$ shown is for writing ACR[0]=1. During the period **Note 1** it may be possible to access other registers (subject to their own access constraints). - 2 For small tehch, BUSY may only occur for a short time or not occur at all. - 3 If tcheн or tehch is exceeded then bankswap may be synchronised to the previous or next input cycle. - 4 This mode should not be used with the IMS A100-G30S variant at clock frequencies above 20.8 MHz. The bankswap timing diagram shows how successive data samples (A and B) can be processed by different sets of coefficients by causing a bankswap to occur between the input of sample A and sample B. The sequence of events is as follows: - T0 No bankswap pending. - T1 GO sampled and found to be high, thus initiating input of data sample A. - T2 Bankswap requested by writing ACR[0]=1. If the minimum timing requirement, tcheh, from T1 to T2 is not met it is possible (but not guaranteed) that the bankswap requested at T2 will occur immediately and thus affect the processing of data sample A. - T3 Bankswap occurs on the first rising edge of CLK upon which GO is sampled (without reference to the state of GO). If the minimum timing requirement, tehch, from T2 to T3 is not met it is possible (but not guaranteed) that the bankswap requested at T2 will not occur at T3 but at the next sampling of GO. - T4 This is the earliest time at which another bankswap can be requested. # Coefficient access timing | Symbol | Parameter | Min. | Max. | Units | Notes | |--------|-----------------------------------------|------|------|-------|-------| | t EHCH | End coefficient access before bankswap | 0 | | ns | | | t CHEL | Start coefficient access after bankswap | 0 | ĺ | ns | | #### **Notes** 1 During this period accesses may be made to registers other than the coefficient registers (subject to their own access constraints). If a bankswap (caused by setting either ACR[0]=1 or SCR[2]=1) occurs at the GO sampling point T6, then no access should be made to the coefficient registers between T5 and T7. #### 3.7 PACKAGE SPECIFICATIONS # 3.7.1 84 pin grid array package Figure 3.6 IMS A100 pin configuration #### Note All VCC pins must be connected to the 5 Volt power supply. All GND pins must be connected to ground. Figure 3.7 84 pin grid array package dimensions | | Millin | netres | Inc | ches | | |-------|-----------|-------------|----------|-----------|-----------------| | DIM | MOM | TOL | NOM | TOL | Notes | | Α | 26.924 | ±0.254 | 1.060 | ±0.010 | | | В | 17.019 | ±0.127 | 0.670 | ±0.005 | | | С | 2.456 | ±0.278 | 0.097 | ±0.011 | | | D | 4.572 | ±0.127 | 0.180 | ±0.005 | | | E | 3.302 | ±0.127 | 0.130 | ±0.005 | | | F | 0.457 | ±0.025 | 0.018 | ±0.001 | Pin diameter | | G | 1.143 | ±0.127 | 0.045 | ±0.005 | Flange diameter | | ] K ] | 22.860 | ±0.127 | 0.900 | ±0.005 | | | L | 2.540 | ±0.127 | 0.100 | ±0.005 | | | М | 0.508 | | 0.020 | | Chamfer | | Packa | age weigh | t is approx | kimately | 7.2 grams | | Table 3.1 84 pin grid array package dimensions # Pin grid array thermal characteristics | Symbol | Parameter | Min | Nom | Max | Units | Notes | |--------|----------------------------------------|-----|-----|-----|-------|-------| | θJA | Junction to ambient thermal resistance | | | 35 | °C /W | 1,2 | - 1 Measured at 400 linear ft/min transverse air flow. - 2 This parameter is sampled and not 100% tested. Figure 3.8 IMS A100 pin configuration #### Note All VCC pins must be connected to the 5 Volt power supply. All GND pins must be connected to ground. Figure 3.9 84 lead quad cerpack package dimensions | | Millin | netres | Inc | | | |-----|--------|--------|-------|--------|-------| | DIM | NOM | TOL | NOM | TOL | Notes | | Α | 38.100 | ±0.508 | 1.500 | ±0.020 | | | В | 26.924 | ±0.305 | 1.060 | ±0.012 | | | C | 20.574 | ±0.203 | 0.810 | ±0.008 | | | D | 19.558 | ±0.254 | 0.770 | ±0.010 | | | E | 0.508 | | 0.020 | | | | F | 1.270 | ±0.051 | 0.050 | ±0.002 | | | G | 2.489 | ±0.305 | 0.098 | ±0.012 | | | Н | 0.635 | ±0.076 | 0.025 | ±0.003 | | | J | 1.143 | ±0.102 | 0.045 | ±0.004 | | | K | 3.099 | | 0.122 | | Max. | | L | 27.940 | | 1.100 | | Max. | | М | 0.178 | ±0.025 | 0.007 | ±0.001 | | Table 3.2 84 lead quad cerpack package dimensions # Quad cerpack thermal characteristics | | Symbol | Parameter | Min | Nom | Max | Units | Notes | |---|--------|----------------------------------------|-----|-----|-----|-------|-------| | į | θJA | Junction to ambient thermal resistance | | | 35 | °C /W | 1,2 | - 1 Measured at 400 linear ft/min transverse air flow. - 2 This parameter is sampled and not 100% tested. # 3.8 MILITARY STANDARD PROGRAM † The INMOS military program is designed to provide class B microcircuits in accordance with 1.2.1 of MIL-STD-883, 'Provisions for the use of MIL-STD-883 in conjunction with compliant non-JAN devices'. The IMS A100M is processed for general applications where component quality and reliability must conform to the guidelines and objectives of military procurement. Suitability for use in specific applications should be determined using the guidelines of MIL-STD-454. Screening procedures are compliant with Method 5004 and the provisions of paragraph 3.3 therein. Quality conformance procedures are compliant with method 5005 using the alternate Group B provisions of paragraph 3.5.2. All electrical testing is performed to guarantee operation at $-55\,^{\circ}\text{C}$ , $+25\,^{\circ}\text{C}$ and $+125\,^{\circ}\text{C}$ . All INMOS military grade components are provided in hermetically sealed ceramic packages. By specifying an INMOS military product, the user can be assured of receiving a product manufactured, tested and inspected in compliance with MIL-STD-883 and one with superior performance for those applications where quality and reliability are of the essence. | 100 Percent<br>Process Step | MIL-STD-883C<br>Method | Test<br>Condition | Comment | |-----------------------------|------------------------|-------------------|-------------------------| | Internal visual | 2010 | В | | | Stabilization bake | 1008 | С | | | Temperature cycle | 1010 | С | | | Constant acceleration | 2001 | D | Y-1 axis | | Seal test | 1014 | В | | | Seal test | 1014 | С | | | Visual inspection | | | INMOS 89-1001 | | Pre burn-in electrical | | | +25°C data sheet | | Burn-in | 1015 | D | | | Post burn-in electrical | | | +25°C data sheet | | PDA | 1 | | 5% max | | Final electrical | | | +125°C data sheet | | Final electrical | | | -55°C data sheet | | External visual | 2009 | | i | | Group A | 5005 | 3.5.1 | A1-A11 | | Group B | 5005 | 3.5.2 | | | Group C | 5005 | | MIL-STD-883C 1.2.1.b.17 | | Group D | 5005 | | MIL-STD-883C 1.2.1.b.17 | t See INMOS document 49-9047 'Military General Processing Specification' for full details. #### 3.9 ORDERING DETAILS The following table indicates the designation of the IMS A100 variants. | INMOS designation | Package | Clock speed | Military/commercial | |-------------------|------------------------|-------------|---------------------| | IMS A100-G21M | Ceramic pin grid array | 21 MHz | military | | IMS A100-G21S | Ceramic pin grid array | 21 MHz | commercial | | IMS A100-Q21M | Flatpack | 21 MHz | military | | IMS A100-Q21S | Flatpack | 21 MHz | commercial | | IMS A100-G17M | Pin grid array | 17 MHz | military | | IMS A100-G30S | Pin grid array | 30 MHz | commercial |