Ford Eectch98

Download as pdf or txt
Download as pdf or txt
You are on page 1of 79

Eectch98-Intro.

fm

TECHNICAL NOTES ON THE EEC-IV MCU


INTRODUCTION
Compiled by Tom Cloud <cloud@peaches.ph.utexas.edu> (font is Courier New)

DISCLAIMER
(The information supplied herein was taken from technical and sales literature, email archives, news groups, and wherever else it could be found. If it helps you, great! Please return the favor by sharing what you learn with me and others.)

None of this data is guaranteed accurate! USE AT YOUR OWN RISK! It is a collection of technical info, opinions and guesses. You can contribute to the effort by letting me know what you learn so that it can be added to and corrected.

PURPOSE
This data has been collected and compiled to help you decipher the EEC-IV inner workings. The EEC MCU probably controls one or more vehicles you own, plus it contains all the components necessary to build an EFI system for any vehicle -- if only we could program and modify it. That is the purpose -- to uncloak the EEC-IV so that we can play with what we bought! Much of the empirical data in this document is specific to the A9L EEC computer. That is the model MotorSport SVO sells for conversion of Mustangs from SD to MAF, and it was stock on 5-speed manual transmission Mustangs from 1989 to 1993, so consensus was reached to pursue this one configuration until it was understood rather than divide our efforts chasing many. Beginning with contacts on the Fordnatics and DIY-EFI mailing lists, the discussion and research into the EEC PCM was soon split off into its own e-mail group, the EECIV Mailing List. To participate in the ongoing work of uncloaking the EEC, join the EEC mail list on the internet. Information on EFI Mailing Lists can be found at

EEC-IV http://eelink.umich.edu/~p-nowak/eec-efi/EEC-Mailadddrop.html to subscribe, send mail (your mail message can be empty) to: eec-subscribe@eelink.net DIY-EFI http://efi332.eng.ohio-state.edu/ to subscribe, send an email to Majordomo@efi332.eng.ohio-state.edu with the following in the body of your message: subscribe diy-efi [your email address *only* if different than your "From" address] Fordnatics http://www.neosoft.com/internet/paml/groups.F/fordnatics

Table 1: EFI Related Mailing Lists

EEC-IV Technical Notes: Introduction

last edited: 9/29/98

Eectch98-Intro.fm

To subscribe, send email to fordnatics-request@lists.best.com and in the body of the message, put the word subscribe

Table 1: EFI Related Mailing Lists

OVERVIEW
The EEC-IV design began in 1978 and was first introduced in 1983 in the 1.6L Escort, Lynx, EXP and LN7 cars. It has gone through several major physical changes, the earliest using a fairly simple two board design with through hole soldered components while the last are more current in technology, showing extensive use of surface mount components and a much more finished and complex appearance. In between, there appears to be a variety of mother/daughter board and other designs. Still, they are all called EEC-IV, although somewhere in its life there was a Ford P/N generational change. The reader is referred to the SAE paper #820900, noted in the reference section at the end of this document, for a much more detailed description of the design goals and operation of the EEC-IV MCU. One person wrote: "The processor used is the 8065 along with several supporting peripheral chips like the DUCE chip which can provide up to 8 PWM outputs and the DARC chip which has 6 channels of timer capture inputs." (Is he talking about the EEC-V here ?) The EEC module is rated to 80 oC (185oF) continuous, 100oC intermittent, so it will be much happier and live longer in the passenger compartment. Some of the later generation 15 and 18 MHz Motorola 8061 processors have a bus loading/edge timing sensitivity that only gets worse at high temperature, so its best to keep the EEC in a more hospitable environment. Additionally, mounting the EEC in the passenger compartment will give you better access to the J3 test port, which is where youll be plugging in an after-market module or any test / modification device. The J3 test port on the side of the ECU box is for developers to plug into -- this is how the after-market chipmakers and others get into the box. The test connector has the micro-controllers multiplexed address/data bus signals on it. It also, very conveniently, has a PROM disable signal. So the chip makers design something that hangs off that connector, disables the computers PROM, and substitutes its own PROM in its place. The reader is encouraged to investigate the Intel 8096 (MCS-96) literature for greater insight into the 8061 processor used in the EEC. One document available from their web site is "27006102.pdf" entitled "APPLICATION NOTE; AP-248; Using The 8096"; Order Number: 270061-002. There are many other related documents available from Intel -- including the use of the A-D converter, the implementation of "fuzzy logic", instrumenting and controlling automotive applications, and other topics. Also, this author has posted a synopsis of the 8096 pinouts and instruction set which is available at several web sites.

ACKNOWLEDGEMENTS / CONTRIBUTORS
Gotta love this job - I collect all the work other people have done and then get to take the credit for it! Someone sent this to me via e-mail and I thought it appropriate here: To steal ideas from one person is plagiarism; to steal from many is research.

EEC-IV Technical Notes: Introduction

last edited: 9/29/98

Eectch98-Intro.fm

Below is a list of the people (and/or other sources) that have either given me information Ive used here or have provided insight or help - theyre the ones that know about this subject. Correction - a consensus was reached to omit references to any people - so, if you contributed something or are quoted in this document and want to be acknowledged, please let me know and Ill be sure youre mentioned in the next rev. (Ive been doing this so long, have talked with so many people, visited so many web sites and read so much literature that I guarantee many people and sources are omitted. Its unintentional. If youve been left out or you see something or someone that should be acknowledged here, please let me know right away.)

* [the names were here]

* Intel MCS-96 literature * Intel Application notes * AP-248; Using the 8096 * "How to Understand, Service, and Modify Ford Fuel Injection and Electronic Engine Control", by Charles O. Probst * SAE paper #820900, "EEC-IV Tomorrows Electronic Engine Controls Today", David Hagen & Dennis Wilkie, Ford Motor Co., Dearborn, MI

Date 9-26-96 2-7-97

Name(s) Subject: Intel 8061 :: EEC-IV e-mail Subject: EEC-IV notes e-mail e-mail

Notes

2-14-1997 Subject: Ignition Writeup 4-22-1997 8096_CPU.DOC 11-26-1997 112601.pdf 9-3-1998 Eectch98-Intro.pdf rev 2 Eectch98-Part1.pdf Eectch98-Part2.pdf Eectch98-Part3.pdf Eectch98-Part4.pdf Eectch98-Part5.pdf Eectch98.pdf rev 3

8096 op-codes, etc

9- -1998

conversion to FrameMaker 5.5

Table 2: Document Revision History

EEC-IV Technical Notes: Introduction

last edited: 9/29/98

Eectch98TOC.fm

Technical Notes on the EEC-IV MCU

Table of contents
TECHNICAL NOTES ON THE EEC-IV MCU ====================================== 1 INTRODUCTION =========================================================== 1 DISCLAIMER - - - - - - - - - - - - - - - - - - - - 1 PURPOSE - - - - - - - - - - - - - - - - - - - - - 1
Table 1: EFI Related Mailing Lists 1

OVERVIEW - - - - - - - - ACKNOWLEDGEMENTS / CONTRIBUTORS Table 2: Document Revision History

2 2
3

TABLE OF CONTENTS ====================================================== 4 HARDWARE =============================================================== 7 THE MICROPROCESSOR / MEMORY CHIP SET: - - - - - - - - - - - 7
Figure Figure Figure Figure Figure Figure Figure Figure Table 3: Table 4: Table 5: Table 6: Table 7: Table 8: 1: 8061 Microprocessor - - 2: 8061 Major Functional Units 3: 8061 CPU - - - - - - 4: 8061 High Input Unit - - 5: High Speed Output Unit - 6: Vector to Service Routine 7: 8763 EPROM - - - - - 8: 81C61 RAM - I/O - - - - EEC Chipset Nomenclature Legend 8061 CPU Pinout - - - - - - 8361 RAM/IO Pinout - - - - - 87C61 RAM/IO Pinout - - - - 8763 EPROM Pinout - - - - - 8061 Chipset Legend - - - - -

7 7 8 8 9 9 9 10 11 11 12 12 12 13

8061 MEMORY MAP - - - - - - - - 8061 INSTRUCTIONS, REGISTERS & INTERRUPTS Table Table Table Table Table Table

14 14
14 14 17 17 17 18

9: 8096-8061/5 Instruction Differences 10: 8096-8061 Op-Codes - - - - - 11: Op-Code Map 00-70 - - - - - - 12: Op-Code Map 80-FF - - - - - - 13: 8061 Interrupt Vectors and Priorities 14: Register Map - - - - - - - -

ECM TEST PORT (J3)

19
- - 19 19

Table 15: ECM Test Port (J3) Pinout - Figure 9: J3 Service Port Connector

- - - - - - - - - - - - - - - -

ECM WIRING HARNESS

20
- - 20 20

Table 16: ECM CABLE PINOUT - - - Figure 10: EEC Main Connector -

- - - - - - - - - - - - - - - -

SOFTWARE ============================================================== THE BASICS - - - - - - - - - - - - - - - - - - INTERNAL DIAGNOSTICS - - - - - - - - - - - - - - - FUEL CONTROL - - - - - - - - - - - - - - - - - IGNITION AND TIMING CONTROL: - - - - - - - - - - - - EEC-IV Technical Notes: Table of Contents

22 22 22 22 24

last edited: 9/29/98

Eectch98TOC.fm

Technical Notes on the EEC-IV MCU


Knock Sensor 25

LIMITED OUTPUT STRATEGY (LOS) OPERATION FUNCTIONS / SCALARS / TABLES - - - -

25 25
- 26 - 26 - 27 28 - 28 - 28 - 28 29 - 29 - 29 - 29 - 30 - 30 - 31 - 31 - 31 - 32 - 32 - 33 - 33 - 33 - 34 - 34 - 34 - 35 - 35 - 35 - 35 - 36 - 36 - 36 - 36 - 37 - 37 38 38 - 38 39 39 39 39 43 45

Table 17: EEC Functions - - - - - - - - Table 18: EEC Scalars - - - - - - - - - Table 19: Example Scalars from Calibrator Demo A9L Constants & Locations - - - - - - - - Table 20: EEC Tables - - - - - - - - - Table 21: Accel Enrichment Fuel [lb/min] - - Table 22: Startup Fuel Ratio - - - - - - Base Fuel A:F Ratio: - - - - - - - - Table 23: Base Fuel A:F Ratio - - - - - - Table 24: Injector Timing - - - - - - - Table 25: Injector Firing Order - - - - - Table 26: Base Spark [Deg BTDC] - - - - - Table 27: Altitude Base Spark [Deg BTDC] - - Table 28: Limp Mode Spark Table [Deg BTDC] - - Table 29: Injector Output Port Table - - - - Table 30: Load Scaling - - - - - - - - Table 31: MAF Transfer Function - - - - - Table 32: WOT Spark Advance vs RPM - - - - Table 33: WOT Spark Advance vs. ECT - - - - Table 34: WOT Spark Advance vs. ACT - - - - Table 35: Accelerator Enrichment Multiplier vs TP Table 36: Open Loop Fuel Multiplier vs. ACT - Table 37: Spark Advance vs. ACT - - - - - Table 38: Spark Advance vs. BP - - - - - - Table 39: Spark Advance Rate vs. RPM - - - - Table 40: Minimum Low Speed Dwell - - - - - Table 41: Minimum High Speed Dwell - - - - Table 42: Maximum Dashpot Clip - - - - - - Table 43: Sea Level Lugging O/L Fuel Multiplier Table 44: Altitude Lugging O/L Fuel Multiplier Table 45: Crank Fuel Pulse Width Multiplier - Table 46: Cranking Fuel Pulse width vs. ECT - Table 47: Injector Offset vs. Battery Voltage - Table 48: Open Loop Fuel Multiplier vs. RPM - Data Pointers - - - - - - - - - - - Idle Speed Constants - - - - - - - - - Table 49: A9L Idle Speed Addresses - - - - Speed Limiters - - - - - - - - - - - Rev Limiter - - - - - - - - - - - - Half Fuel Limits - - - - - - - - - - A9L Tables - - - - - - - - - - - - - A9L Table Format Explanation - - - - - - - DA1 Constants & Locations - - - - - - - - -

SENSORS =============================================================== EGO - - - - - - - - - - - - - - - - - - - - EGR - - - - - - - - - - - - - - - - - - - - ACT - - - - - - - - - - - - - - - - - - - - TFI / PIP - - - - - - - - - - - - - - - - - - Table 50: ACT Transfer Function -

46 46 46 47 47 48

- 47

KNOCK SENSOR

EEC-IV Technical Notes: Table of Contents

last edited: 9/29/98

Eectch98TOC.fm

Technical Notes on the EEC-IV MCU VSS AFM -

48 48
- 48 49 - 49 - 50 - 50

Table 51: Testing AFMs Table 52: Table 53: Table 54:

Knock Sensor Data - - - - - - - - - - - Mustang MAF Transfer Function MAF Calibration - - - MAF Calibration - - - -

- - - - - - - - - - - - - -

EXTERNAL (SERVICE PORT) CONTROL ======================================= 52 EEC MEMORY CONTROL - - - - - - - - - - - - - - - 52


Table 55: Memory Control Functions Service Port Adaptors - - - - PLDs - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 53 54 54

EEC-IV / EEC-V FLASH MEMORY

54

EEC EFI MODIFICATIONS & UPGRADES ====================================== 56 SD TO MAF CONVERSION - - - - - - - - - - - - - - - 56 NOTES FOR TRUCK APPLICATIONS: - - - - - - - - - - - - 58 TUNING - - - - - - - - - - - - - - - - - - - 59
Introduction - - - - - - - - - - - - - - - - - - - What Is Being Modified - - - - - - - - - - - - - - - - List Of Tables - - - - - - - - - - - - - - - - - - Table 56: Spark Table (RPM vs Vacuum kPa) - - - - - - - - - - - Tuning Tools - - - - - - - - - - - - - - - - - - - Table 57: Power Enrich Spark (RPM vs. Added Spark Advance) - - - - - Table 58: Volumetric Efficiency (MAP vs. RPM) - - - - - - - - - Table 59: Volumetric Efficiency WOT Enable (RPM vs. Additional fuel factor) Table 60: %Throttle Position Sensor for Wide Open Throttle (RPM vs. % factor) O2 Sensors And Indicators - - - - - - - - - - - - - - Where To Start - - - - - - - - - - - - - - - - - - Idle - - - - - - - - - - - - - - - - - - - - - Light Cruise - - - - - - - - - - - - - - - - - - WOT - - - - - - - - - - - - - - - - - - - - - Mild Performance Engines, Engine Swaps - - - - - - - - - - Real Fire Breathing Hot Rods - - - - - - - - - - - - - - General Tuning Tips - - - - - - - - - - - - - - - - - A Note About Timing - - - - - - - - - - - - - - - - - Maf System Differences - - - - - - - - - - - - - - - - Attachment A - - - - - - - - - - - - - - - - - - - 59 60 60 60 61 61 61 61 61 62 62 62 63 64 65 65 66 67 67 68

EPEC -

69

REFERENCE ============================================================= 72 EEC APPLICATIONS - - - - - - - - - - - - - - - - 72


Table 61: PCM Applications - 72

TERMS -

76
- 76

Table 62: EEC Related Terms -

EEC-IV REFERENCE SOURCES: AFTER-MARKET SUPPLIERS: - -

78 79

EEC-IV Technical Notes: Table of Contents

last edited: 9/29/98

Figure: 8061 Microprocessor


Eectch98-Part1.fm

Figure: 8061 Major Functional Units

Technical Notes on The EEC-IV MCU

HARDWARE
Compiled by Tom Cloud <cloud@peaches.ph.utexas.edu> (font is Courier New)

THE MICROPROCESSOR / MEMORY CHIP SET:


The micro-controller is an Intel 8061, a close cousin to the Intel 8096. It is supplied by three manufacturers: Intel, Toshiba (6127) and Motorola, though the Motorola units are said to slip spec a little and differ in their timing XTAL CONTROL PROCESSOR MBUS slightly from the others. MB0-MB7 INSTRUCTION M B It was originally (in 1978) REGISTER B U U F intended to operate in conS F C OPCODE junction with an 8361 ROM. T There are some major differences between the 8061 and 8096 (e.g. pinouts, bus layout, etc.), but most of the code appears transferable. It is organized internally as a 16-bit machine with a double bus structure consisting of CPU, memory controller, clock generator, I/O and co-processors, A/D converter, watchdog timer and interrupt controller.
R L & I / O I N T E R F A C E ANALOG INPUTS 13 HI SPEED INPUTS 8 HI SPEED OUTPUTS 10 LO SPEED OUTPUTS 8 BIDIRECT I/O 2 I / O C I R C U I T S ADDR ADDR A-BUS 8 DATA ADDR ADDR/ DATA

INTERRUPT CONTROLLER, WATCHDOG TIMER, I/O STATUS REGISTER

RALU PROGRAM COUNTER DATA

REGISTER FILE (120 X 16) STACK POINTER DATA 8 LSBs B U F F

DATA DATA D-BUS (16)

8061 MICROPROCESSOR

The high speed hardware / register structure is a design by Ford engineers to simplify the processing of digital I/O signals. Ford chose to design a custom microprocessor - memory comXTAL bin ati on and th e 8 06 1 a nd D-BUS A-BUS 8361 were the result. Those A/D two ch ips fo rm a t wo -ch ip CONVERTER CLOCK 8 microcomputer. 16
GENERATION

The re wer e s eve ral d esi gn goals for this custom microprocessor: 1. An I/O intensive circuit with hi-speed digital I/O capability. 2. A fast, on-chip, multichannel A/D converter. 3. Hardware multiply and divide. 4. Multi-level,

HSI

HSO

REGISTER ALU

M BUS MEMORY CONTROLLER

WATCHDOG TIMER

REGISTER FILE CPU

INTERRUPT CONTROLLER 8061 Major Functional Units

EEC-IV Technical Notes: Hardware

last edited: 9/29/98

Figure: 8061 CPU Figure: 8061 High Input Unit prioritized interrupts. 5. Variable data types (bit, byte, word & double word). 6. A watchdog timer. 7. A powerful yet regular software architecture. 8. A large memory address space with minimum off-chip memory access time. The 8061 microcomputer chip features a CPU, 256 bytes of RAM, an A/D converter and independent co-processor circuitry to expedite digital signal I/O handling. There are 13 analog lines, 8 hi-speed digital inputs, 10 hi-speed digital outputs, 8 lospeed digital outputs and 2 bi-directional I/O lines, making a total of 41 I/O lines on the CPU chip. The A/D converter is a 13-channel, 10-bit successive approximation unit.
D-BUS 16 INSTRUCTION REGISTER CONTROL UNIT A-BUS 8
Eectch98-Part1.fm

The internal 256 bytes of RAM in the 8061 can be referenced as bytes, words or double words, allo wing freq uentl y use d var iabl es to be stored on-chip for faster access. The two high speed co-processors on the 8061 (HSI and HSO) were implemented to reduce signal processing overhead on the CPU. An 11-deep FIFO for the high speed input (HSI) and a 12slot content addressable memory (CAM) for the high speed output (HSO) are used. Operation of both HSI & HSO are synchronized with an internal master I/O timer which is clocked every 2.4 microseconds (15 MHz crystal).

RALU

The HSI looks for transitions on its input lines and records (1) the time, from the master I/O timer, and (2) the transition. It can be programmed to look at selected inputs for positive and negative transitions and can be 8061 CPU programmed to generate an interrupt to the CPU when the first entry is made into the FIFO or when the next entry would cause the FIFO to overflow. The HSO can be programmed to generate transitions on any of its output lines at specified times. HSO commands are stored in one of the twelve CAM registers, which are 24 bits wide. Of the 24 bits in each register, 16 specify the time the action MASTER 0 INPUT I/O is to occur, and 8 specify 8 HS TRANSITION TIMER the action(s). The CAM file INPUTS DETECTOR 7 rotates one position per state time, so it takes 12 state events for the hold16 8 ing buffer to access all 12 TIME DATA registers. Therefore the FIFO STACK (11 X 24) FIFO OVERFLOW time resolution of the HSO unit is 12 state times or I/O STATUS 2.4 microseconds if a 15 MHz 7 2 1 0 crystal is used.
24 HOLDING REGISTER DATA AVAILABLE TO INTERRUPT UNIT

ADDRESS REGISTER

REGISTER FILE

Two novel architectural concepts were used. One, address and data is multi-

High Speed Input Unit

EEC-IV Technical Notes: Hardware

last edited: 9/29/98

Eectch98-Part1.fm
HIGH LOW PRIORITY PRIORITY

HOLDING REGISTER COMMAND TIME OUTPUT INTERRUPT 1 OUTPUT INTERRUPT 2 24 0

TRANSITION DETECTOR

PENDING REGISTER

MASK REGISTER

CONTENT ADDRESSABLE MEMORY (CIRCULATING)

COMMAND DECODER

10 HS OUTPUTS
GATE

9 TIME 16 MASTER I/O TIMER High Speed Output Unit 16 8 COMMAND


VECTOR TO SERVICE ROUTINE INTERRUPT GENERATOR PRIORITY ENCODER

COMPARATOR

8061 Interrupt Structure plexed on the external memory bus (M-bus) to minimize the number of memory interface pins. This isn't novel, but the collateral addition of slave program counters on the memory chips is. Second, a large (256 bytes of RAM) general purpose register file was designed into the 8061". It can be referenced as byte, word or double word allowing storing and accessing data directly on-chip.

The 8061 is a double-bus structure machine with CPU, memory controller, clock, I/O with co-processors, A/D converter, watchdog timer, and an interrupt controller. The CPU consists of the register file, the register-arithmetic logic unit (RALU), and a control unit. Note that the RALU does not use an accumulator but operates directly on any register in the register file, resulting in code length and execution speed improvements. The control unit consists of the instruction register and associated circuitry which decodes the instructions and generates the correct ENABLE RP0 READ I sequence of internal conONLY RP5 / PORT trol signals to execute O instructions. The clock generator in the 8061 divides the crystal frequency, internally, by three to provide a duty cycle of 33%. The clock signal period, called one state time, equals three oscillator periods. A watchdog timer is incremented every state time. It is a 16-bit counter that reinitializes the system when it overflows to provide a means of recovering from a
8 SLAVE PROGRAM COUNTER DATA ADDRESS REGISTER 16 A D D R E S S C I R C U I T S READ-ONLY MEMORY (16K X 16) D A T M A U O X U T 8

16

ADDR

MACHINE STATE LOGIC

B I U N F F CONTROL SIGNALS

B O U U F T F

DATA

TRISTATE 8763 EPROM MBUS MB0-MB7

EEC-IV Technical Notes: Hardware

last edited: 9/29/98

Eectch98-Part1.fm

software fault. The user must periodically reset the watchdog timer to prevent register overflow and subsequent re-start. There are 8 interrupt sources in the 8061. A positive transition from any one of the sources sets a corresponding bit in the pending register. A programmable mask register determines if the particular interrupt will be recognized or not. Interrupts can occur at any time and simultaneous interrupts are accepted. Conflicts are resolved with a two-level sequential priority hierarchy which establishes the order of servicing. A corresponding vector automatically identifies the location of each interrupt service program. A software stack, which can be created anywhere in memory, can be used for temporary storage of important program data (e.g. the PC and PSW) during execution of interrupt service routines. The 8061 can address up to 64k bytes of memory, supports bit, byte, word and doubleword data types with six addressing modes and has eleven instruction categories defined. The assembly language programmer can create very fast, compact programs by using the direct addressing mode and careful movement of data between external memory and the register file. The 8361 ROM chip contains 8k bytes of program memory plus 128 bytes of additional RAM. Data transfer between the 8763 ROM and the 8061 is controlled by the memory controller in the 8061. Addresses for instruction fetches from the ROM are maintained in a slave PC in the 8061 memory controller and in a corresponding counter in the 8763. The slave PC functions like a traditional PC, being automatically incremented after each fetch and updated whenever the CPU executes a program jump. The counter in the ROM is independent of the slave PC but DATA is identical to it. ENABLE Addresses are transmitted SLAVE on the M-bus from the slave I PROGRAM N PC to the ROM under two COUNTER 16 8 D A A 8 conditions, when the C A 5 T S I/O-0 address is initialized at D I RANDOM-ACCESS A S R I D MEMORY EXECUTE Y the start of program execuC I/O R I/O-4 / ENABLE U PORT O O (1K X 16) tion or when a program jump 8 REGISTER 16 E I U S T D T occurs. The slave PC conS S A 5 cept eliminates the need to T M DATA A U send an address to exterADDRESS X 8 REGISTER 16 nal memory for each ins truc tion -- tha t on ly B B ADDR/DATA DATA being necessary when a I U O U N F U F br a nc h o c cu rs or at pr o F T F MACHINE gram initiation. TRISTATE LOGIC The 8061 is an 8096 with a few extra instructions MBUS 81C61 RAM - I/O MB0-MB7 added. One is a very powerful conditional jump to complement the high speed I/O units. This instruction, the jump on bit equals zero, is used to test any one of the eight bits of a given byte and jump if the bit equals zero (is this the JBC/JNB command?). Other conditional jumps were added to avoid extensive data shifts. With a 15 MHz input frequency, the 8061 can perform a 16-bit addition in 0.8 microseconds and a 16 x 16 bit multiply or a 32/16 bit divide in 5.2 microseconds (using the hardware multiply and divide feature). For typical applications, based on a normal instruction mix, instruction execution times average 1 to 2 microseconds. It seems to have the same functional pins as the 8096, but it's in a custom package, so the pinout is different. Most of the signals should be able to be found with a scope or
CONTROL SIGNALS STATE

EEC-IV Technical Notes: Hardware

10

last edited: 9/29/98

Eectch98-Part1.fm

logic analyzer. The 8096 has a multiplexed address/data bus. The address/data bus signals are on the service port connector (J3) along with a few others, possibly including the address latch enable, read strobe, write strobe, and EPROM disable. There are two hardware versions of the 8061 chip. One is a 40 pin DIP, with reduced I/O and the other is a square LCC 68 pin package with all the functions implemented. The multiplexed M-bus scheme used on the 8061 is not new, but the slave program counter used on the 8763 is. It appears that the address / multiplexing scheme is similar to that of the 8085 which has AD0 .. AD7 and then A8 .. A15 so the 8085 latches the address information A7:0, and maintains A8:15 while it is using AD0 .. AD7 as D7:0 .... It is speculated that the only internal EEC memory you could possibly get would be the FLASH memory, if it was ever used. Look for a PLCC package, probably 32 pin, that should be a standard 28F010 12V write, erase/5V read Flash available from TI, Intel, AMD, and others. Might be labeled 81C65 or 81C62. LEGEND
ADDR ASSY A-BUS BIDIRECT BUFF CTRL D-BUS HI ADDRESS ASSEMBLY ADDRESS BUS BIDIRECTIONAL BUFFER CONTROL DATA BUS HIGH I/O LO LSB MBus EPROM MUX RAM RPn INPUT/OUTPUT LOW LEAST SIGNIFICANT BIT MEMORY BUS ERASABLE READ-ONLY MEMORY MULTIPLEXER RANDOM ACCESS MEMORY READ-ONLY PORT INPUT

Table 3: EEC Chipset Nomenclature Legend 8061 CPU (IC-1)


1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 GND unused unused /RESET HSO9 HSO8 HSO7 HSO6 HSO5 HSO4 HSO3 HSO2 HSO1 HSO0 VSS xtal2 xtal1 LSO7 LSO6 LSO5 LSO4 LSO3 LSO2 LSO1 LSO0 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 A4 A5 A7 A6 A2 A0 A1 A3 AVCC VSS NC VBB HSI0 HSI1 HSI2 HSI3 HSI4 HSI5 HSI6 HSI7 VCC NC DI IT

Table 4: 8061 CPU Pinout

EEC-IV Technical Notes: Hardware

11

last edited: 9/29/98

Eectch98-Part1.fm

8061 CPU (IC-1)


25 26 27 28 29 30 31 32 33 34 I/O1 I/O0 EXT INT VCC AVSS A10 A11 A9 A8 A12 59 60 61 62 63 64 65 66 67 68 /ST /PAUSE MB0 MB1 MB2 MB3 MB4 MB5 MB6 MB7

Table 4: 8061 CPU Pinout 81C61/2 RAM/IO/CART (IC-3)


1 2 3 4 5 6 7 8 9 10 11 12 OCP4 OCP3 OCP2 OCP1 OCP0 NC-RCV VCC NC-\XMT ENA MB7 MB6 MB5 13 14 15 16 17 18 19 20 21 22 23 24 MB4 MB3 MB2 MB1 MB0 NC NC /ST IT DI NC VSS

Table 5: 8361 RAM/IO Pinout 87C61 RAM/IO (IC-7)


1 2 3 4 5 6 7 8 9 10 11 12 CPU-68, J3-19 CPU-67, J3-17 CPU-66, J3-15 MB7 MB6 MB5 GND (?) KAPWR VCC GND (?) /OE 13 14 15 16 17 18 19 20 21 22 23 24 GND VSS GND (?) /ST IT DI CPU-65, J3-13 CPU-64, J3-11 CPU-63, J3-9 CPU-62, J3-7 CPU-61, J3-5 MB4 MB3 MB2 MB1 MB0

Table 6: 87C61 RAM/IO Pinout 8763 EPROM (IC-8)


1 2 3 4 5 6 7 +5 GND J3-22, 1K to +5V J3-16, 10K to +5 /TSTSTB /EPROMDIS RP0 RP1 RP2 RP3 VCC 13 14 15 16 17 18 19 CPU-65, J3-13 CPU-64, J3-11 CPU-63, J3-9 CPU-62, J3-7 CPU-61, J3-5 1k to +5V +5V MB4 MB3 MB2 MB1 MB0 VCC, VPP VCC, TEST

Table 7: 8763 EPROM Pinout


EEC-IV Technical Notes: Hardware

12

last edited: 9/29/98

Eectch98-Part1.fm

8763 EPROM (IC-8)


8 9 10 11 12 GND J3-12 CPU-68, J3-19 CPU-67, J3-17 CPU-66, J3-15 RP4 /MRESET MB7 MB6 MB5 20 21 22 23 24 GND CPU-59, J3-21 CPU-58, J3-23 CPU-57, J3-25 /ST IT DI /CE VSS

Table 7: 8763 EPROM Pinout LEGEND:


RP OCP MB EER DAR DI IT STB ROM PORT OFF CHIP PORT EXTERNAL MEMORY BUS EXECUTE ENABLE REGISTER DATA ADDRESS REGISTER DIRECTION INDICATOR INSTRUCTION TRANSFER STROBE

Table 8: 8061 Chipset Legend Hardware development tools used in conjunction with the EEC-IV include: 1. Engineering Console -- a lab instrument for real-time program debug and monitor of the EEC-IV system. 2. Calibration Console -- a portable unit for vehicle use to permit field display and modification of program memory. 3. D/A Converter Unit -- an add-on feature to the calibration console that converts EEC-IV system digital outputs to analog form for data logging by external recording equipment. There is a Production Code Release System binary file verification and comparison program for release of production binary files to outside suppliers for ROM manufacturing.

EEC-IV Technical Notes: Hardware

13

last edited: 9/29/98

Eectch98-Part1.fm

8061 MEMORY MAP


The 8061 uses the same address space for program and for data memory and can execute instructions from any memory address. Its addressing range is 64k locations and the first 256 locations are on-chip and refer to the internal register file. All other memory resides externally. FFFFH ENGINEERING CONSOLE CALIBRATION CONSOLE E000H C000H

0F 0E 0D 0C 0B 0A 09 08 07 06 05 04 03 02 01 00

H.S. TIME H.S. BUFFER H.S. MASK H.S. DATA I/O STATUS INT. PEND INT. MASK TIMER A/D HI A/D LO I/O PORT L.S. PORT ZERO REG READ

H.S. TIME H.S. COMMAND H.S. MASK NU I/O STATUS INT. PEND INT. MASK NU WATCHDOG A/D COMMAND I/O PORT L.S. PORT NU WRITE

PROGRAM MEMORY (40k) INTERRUPT VECTORS 2010H - 201FH 2000H ENGINEERING CONSOLE (4k) CALIBRATION CONSOLE (4k) KAM (512) FUTURE USE (1536) EXTERNAL RAM (768) 1000H 0C00H 0A00H 0400H 0100H 00FFH

INTERNAL REGISTERS (238) 0000H

8061 INSTRUCTIONS, REGISTERS & INTERRUPTS


OP-CODE
10 E3 F1 F4 F5 F6 FD FF nu BR nu nu nu nu NOP RST

8096
nu nu RETI nu nu nu nu NOP

8061
nu

8065
ROMBANK RETEI BANK0 BANK1 BANK2 BANK3 NOP

Table 9: 8096-8061/5 Instruction Differences OP-CODE 8096


00 01 02 03 04 05 06 07 08 09 0A SKIP CLR NOT NEG nu DEC EXT INC SHR SHL SHRA DECW SEXW INCW SHRW SHLW ASRW decrement word sign extend int to long increment word logical right shift word shift word left arithmetic right shift word rename rename rename rename rename rename

8061/5
SKP CLRW CPLW NEGW clear word complement word negate integer

DESCRIPTION
skip - 2 byte no operation

DIFFERENCE
rename rename rename rename

Table 10: 8096-8061 Op-Codes

EEC-IV Technical Notes: Hardware

14

last edited: 9/29/98

Eectch98-Part1.fm

OP-CODE 8096
0B 0C 0D 0E 0F 10 11 12 13 14 15 16 17 18 19 1A 1B 1C 1D 1E 1F 20-27 28-2F 30-37 38-3F 40-43 44-47 48-4B 4C-4F 50-53 54-57 58-5B 5C-5F 60-63 64-67 68-6B 6C-6F 70-73 74-77 78-7B 7C-7F 80-83 84-87 88-8B 8C-8F 90-93 94-97 98-9B 9C-9F A0-A3 A4-A7 A8-AB AC-AF B0-B3 CLRB NOTB NEGB nu DECB EXTB INCB SHRB SHLB SHRAB nu nu nu nu nu SJMP SCALL JBC JBS AND ADD SUB MULU ANDB ADDB SUBB MULUB AND ADD SUB MULU ANDB ADDB SUBB MULUB OR XOR CMP DIVU ORB XORB CMPB DIVUB LD ADDC SUBC LDBZE LDB nu SHRL SHLL SHRAL NORML

8061/5
SHRDW SHLDW ASRDW NORM ROMBANK CLRB CPLB NEGB DECB SEXB INCB SHRB SHLB ASRB clear byte complement byte negate byte decrement byte

DESCRIPTION
logical right shift double word shift double word left arithmetic right shift double word normalize long integer

DIFFERENCE
rename rename rename rename not in 8096 same rename same same rename same same same rename

sign extend 8-bit in to 16-bit int increment byte logical right shift byte shift byte left arithmetic right shift byte

SJMP SCALL JNB JB AN3W AD3W SB3W ML3W AN3B AD3B SB3B ML3B AN2W AD2W SB2W ML2W AN2B AD2B SB2B ML2B ORRW XRW CMPW DIVW ORRB XRB CMPB DIVB LDW ADCW SBBW LDZBW LDB

short jump short call jump if bit clear jump if bit set logical and words (3 operands) add words (3 operands) subtract words (3 operands) multiply unsigned words (3 operands) logical and bytes (3 operands) add bytes (3 operands) subtract bytes (3 operands) multiply unsigned bytes (3 operands) logical and words (2 operands) add words (2 operands) subtract words (2 operands) multiply unsigned words (2 operands) logical and bytes (2 operands) add bytes (2 operands) subtract bytes (2 operands) multiply unsigned bytes (2 operands) logical or words logical exclusive or words compare words divide unsigned words logical or bytes logical exclusive or bytes compare bytes divide unsigned bytes load word add words with carry subtract words with borrow load word with byte, zero extended load byte

same same rename rename split split split split split split split split split split split split split split split split rename rename rename rename rename rename same rename rename rename rename rename same

Table 10: 8096-8061 Op-Codes


EEC-IV Technical Notes: Hardware

15

last edited: 9/29/98

Eectch98-Part1.fm

OP-CODE 8096
B4-B7 B8-BB BC-BF C0/2/3 C1 C4/6/7 C5 C8-CB CC/E/F CD D0 D1 D2 D3 D4 D5 D6 D7 D8 D9 DA DB DC DD DE DF E0 E1 E2 E3 E4 E5 E6 E7 E8 E9 EA EB EC ED EE EF F0 F1 F2 F3 F4 F5 F6 F7 F8 F9 FA FB TRAP CLRC SETC DI EI ADDCB SUBCB LDBSE ST nu STB nu PUSH POP nu JNST JNH JGT JNC JNVT JNV JGE JNE JST JH JLE JC JVT JV JLT JE DJNZ nu nu BR nu nu nu LJMP nu nu nu nu nu nu nu LCALL RET ----PUSHF POPF

8061/5
ADCB SBBB LDSBW STW STB PUSHW POPW JNST JLEU JGT JNC JNVT JNV JGE JNE JST JGTU JLE JC JVT JV JLT JE DJNZ

DESCRIPTION
add bytes with carry subtract bytes with borrow load integer with byte, sign extended store word store byte push word pop word jump if sticky bit is clear jump if unsigned not higher jump if signed greater than jump if carry flag is clear jump if overflow trap is clear jump if overflow flag is clear jump if signed greater than or equal jump if not equal jump sticky bit is set jump if unsigned higher jump if signed less than or equal jump if carry flag is set jump if overflow trap is set jump if overflow flag is set jump if signed less than jump if equal decrement and jump if not zero

DIFFERENCE
rename rename rename rename same rename rename same rename same same same same same same same rename same same same same same same same

branch indirect

not in 8061/5

JUMP

long jump

rename

CALL RET PUSHP POPP BANK 0 BANK 1 BANK 2 INT CLC STC DI EI

long call return from subroutine push flags pop flags 8065 only - not in 8096 8065 only - not in 8096 8065 only - not in 8096 software trap (internal use only, not in assembler) clear carry flag set carry flag disable interrupt enable interrupt

rename same not in 8096 rename rename

RETEI/RETI retei-8065 reti - 8061

same rename same same

Table 10: 8096-8061 Op-Codes


EEC-IV Technical Notes: Hardware

16

last edited: 9/29/98

Eectch98-Part1.fm

OP-CODE 8096
FC FD FE FF CLRVT NOP RST

8061/5
CLRVT BANK 3 NOP NOP 8096/8061

DESCRIPTION
clear overflow trap changes multiply/divide to signed system reset in 8096 NOP in 8061/5

DIFFERENCE
same different rename different

PREFIX SIGND/ALT

Table 10: 8096-8061 Op-Codes

The bank selection opcodes are 8065 -- as that is the difference between them, memory bank selection capabilities. 00
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F SKP CLRW CPLW NEGW (ua) DECW SEXW INCW SHRW SHLW ASRW (ua) SHRDW SHLDW ASRDW NORM

10
ROMBANK* CLRB CPLB NEGB (ua) DECB SEXB INCB SHRB SHLB ASRB (ua) (ua) (ua) (ua) (ua)

20
SJMP SJMP SJMP SJMP SJMP SJMP SJMP SJMP SCALL SCALL SCALL SCALL SCALL SCALL SCALL SCALL

30
JNB0 JNB1 JNB2 JNB3 JNB4 JNB5 JNB6 JNB7 JB0 JB1 JB2 JB3 JB4 JB5 JB6 JB7

40
AN3W d AN3W = AN3W @ ANEW () AD3W d AD3W = AD3W @ AD3W () SBEW d SB3W = SB3W @ SB3W () ML3W d ML3W = ML3W @ ML3W ()

50
AN3B d ANDB = AN3B @ AN3B () AD3B d AD3B = AD3B @ AD3B () SB3B d SB3B = SB3B @ SB3B () ML3B d ML3B = ML3B @ ML3B ()

60
AN2W d AN2W = AN2W @ AN2W () AD2W d AD2W = AD2W @ AD2W () SB2W d SB2W = SB2W @ SB2W () ML2W d ML2W = ML2W @ ML2W ()

70
AN2B d AN2B = AN2B @ AN2B () AD2B d AD2B = AD2B @ AD2B () SB2B d SB2B = SB2B @ SB2B () ML2B d ML2B = ML2B @ ML2B ()

Table 11: Op-Code Map 00-70 80


00 ORRW d 01 ORRW = 02 ORRW @ 03 ORRW () 04 XRW d 05 XRW = 06 XRW @ 07 XRW () 08 CMPW d 09 CMPW = 0A CMPW @ 0B CMPW () 0C DIVW d 0D DIVW = 0E DIVW @ 0F DIVW ()

90
ORRB d ORRB = ORRB @ ORRB () XRB d XRB = XRB @ XRB () CMPB d CMPB = CMPB @ CMPB () DIVB d DIVB = DIVB @ DIVB ()

A0
LDW d LDW = LDW @ LDW () ADCW d ADCW = ADCW @ ADCW () SBBW d SBBW = SBBW @ SBBW () LDZBW d LDZBW = LDZBW @ LDZBW ()

B0
LDB d LDB = LDB @ LDB () ADCB d ADCB = ADCB @ ADCB () SBBB d SBBB = SBBB @ SBBB () LDSBW d LDSBW = LDSBW @ LDSBW ()

C0
STW d (ua) STW @ STW () STB d (ua) STB @ STB () PUSHW d PUSHW = PUSHW @ PUSHW () POPW d (ua) POPW @ POPW ()

D0
JNST JLEU JGT JNC JNVT JNV JGE JNE JST JGTU JLE JLC JVT JV JLT JE

E0
DJNZ (ua) (ua) (ua) (ua) (ua) (ua) JUMP (ua) (ua) (ua) (ua) (ua) (ua) (ua) (ua) RET

F0
RETI/RETEI* PUSHP POPP BANK0* BANK1* BANK2* INT** CLC STC DI EI CLRVT BANK3* ALT*/SIGND/S NOP

Table 12: Op-Code Map 80-FF Priority:


Highest

Interrupt
High-Speed Input #0

16-Bit Address
0x201E

Table 13: 8061 Interrupt Vectors and Priorities


EEC-IV Technical Notes: Hardware

17

last edited: 9/29/98

Eectch98-Part1.fm

Priority:
High High Low Low Low Low Lowest

Interrupt
High-Speed Input #1 HSO Port Output Interrupt #1 External Interrupt HSI Port Input Data Available A/D End-Of-Conversion Master I/O Timer Overflow HSO Port Output Interrupt #2

16-Bit Address
0x201C 0x201A 0x2018 0x2016 0x2014 0x2012 0x2010

Table 13: 8061 Interrupt Vectors and Priorities At Reset, PC = 0x2000 in Memory Bank #8 addr
0000:0001 ZERO 0002 0003 0004: 0005: 0008: LOW SPEED I/O uni-directional I/O bi-directional A/D LO A/D HI INTERRUPT MASK bit 7: HSI0 bit 6: HSI1 bit 5: HSO output int 1 bit 4: External interrupt bit 3: HSI data ready bit 2: A-D complete bit 1: I/O timer ovflw bit 0: HSO int 2 0009: 000A: INTERRUPT STATUS (same mask as above) IO STATUS IO STATUS bit 5: interrupt priority 1/0 hi/low bit 4: interrupt status 1/0 int serv/prog exe bit 3: A-D complete bit 2: HSI data ready bit 1: HSI input ovflw bit 0: HSO output ovflw 000B: 000C: 000D: HSI sample HSI input mask HSI data hold R/O HSI input mask HSO command hold (write byte after HSO time) bits 0-3: select HSO channel bit 4: output level bit 5: interrupt enable 0FH = software interrupt 000E:000F HSI time hold 0010:0011 STACK POINTER 0012:00FF general register file HSO time hold (write word before HSO command) STACK POINTER general register file A/D channel # watchdog timer R/O INTERRUPT MASK

READ
R/O

WRITE

0006:0007 I/O timer

Table 14: Register Map

EEC-IV Technical Notes: Hardware

18

last edited: 9/29/98

Eectch98-Part1.fm

29

27

25

23

21

19 17

15

13

11

30

28

26

24

22

20 18

16 14

12

10

(View facing connector on PCM.)

ECM TEST PORT (J3)


The pinouts are derived from the J3 Test Port on a SD unit for an '87 Mustang (DA1 / E7SF-12A650-A1B). Looking at the MCU facing the service port (from the rear of the mating plug) the connector is numbered from right-to-left with odd numbers on the component side and the even numbers on the wiring side. It is a 15/30 terminal, card-edge connector with .1" spacing. (The table below is arranged for the pins to be read from left-to-right, top first.) PIN SIGNAL / FUNCTION
29 27 25 23 21 19 17 15 13 11 9 7 5 3 1 30 28 26 24 22 20 18 16 14 12 10 8 6 4 2 PWR GND VPWR DI IT STROBE\ D7 D6 D5 D4 D3 D2 D1 D0 KA5V VREF (+5) PWR GND VPWR BS0 BS3 TSTSTB\ PROGRAM RAMDISABLE\ EPROMDISABLE\ ERASE MRESET\ RESET\ PAUSE\ EXTINT (high for access) VCC 25 IC4-74001 pin 13 3 60 9 1K TO +5 only 9 2 10K TO +5 only 1 1K TO +5 only 37,57 battery + 26

MCU PIN
40,60 37,57

CPU 8061

RAM 81C61 EPROM 8763

notes
battery +

57 58 59 68 67 66 65 64 63 62 61

22 21 20 10 11 12 13 14 15 16 17 7

22 21 20 10 11 12 13 14 15 16 17

Table 15: ECM Test Port (J3) Pinout There're 14 pins from the 8763 EPROM on the connector, 2 pins from the 87C61 RAM-I/O on the connector, 1 pin from the 8061 CPU and 1 pin from a 16-pin logic chip.

EEC-IV Technical Notes: Hardware

19

last edited: 9/29/98

Eectch98-Part1.fm

(looking at connector from outside MCU)

ECM WIRING HARNESS


The table below lists several MCU cabling pinouts. The first is for a Mustang A9L EEC, used 1989 to 1993 302 MAF, manual transmission applications. The second, for a 1991 Ranger 2.3L Dual Plug EFI Engine (from Mitchell International On-line manual (c) 1992), was submitted by <tnye@mansci.watstar.uwaterloo.ca>. The next three columns were done by the author and are from the Ford wiring diagrams (yes, I actually buy the factory manuals) -- and they don't use the same naming convention as the first two. '91 4.9, 5.0, 5.8 Fseries w/o E4OD
Bty to load

Mustang No A9L
1 2 3 4 VSS + IDM Kapwr

'91 Ranger 2.3


Kapwr BOO VSS + IDM

'91 4.9, 5.0, 5.8 Fseries w E4OD


Bty to load

'91 7.3 diesel Fseries w E4OD


Bty to load

Description
keep-alive power Brake On/Off switch Vehicle speed sensor positive Ignition Diagnostic monitor

stop lamp sw to stop lamp sw turn sig sw to stop lamp VSS elect sw to ignition coil VSS return engine coolant fuel sply pump relay EEC data compressor clutch feed thermactor diverter valve VSS elect sw to ignition coil VSS return engine coolant fuel sply pump relay EEC data compressor clutch feed thermactor diverter valve 4X4 lo-range indicator 4X4 lo-range indicator VSS elect sw to ignition coil VSS return xmsn oil temp

6 7 8 9 10 11 12

VSS ECT FPM

VSS ECT FPM DATA -

Vehicle speed sensor negative Engine coolant temp sensor Fuel pump monitor

ACC AM 2

ACC

A/C compressor clutch Air management solenoid 2

14 15 16 17 IGN GND STO/MIL

MAF (CA only) MAF RTN (CA only) IGN GND STO/MIL dedicated GND to dedicated GND TFI to TFI check engine lamp check engine lamp check engine lamp Ignition ground Self-test output check Engine

20 21

CSE GND ISC/BPA

CSE GND ISC/BPA

GND ISC

GND ISC

GND

Case ground Idle speed control / bypass air

Table 16: ECM CABLE PINOUT

EEC-IV Technical Notes: Hardware

20

last edited: 9/29/98

Eectch98-Part1.fm

No
22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38

Mustang A9L
FP KS PSPS ACT VREF EVP HEGO NDS

'91 Ranger 2.3


FP PSPS ACT VREF HEGO NDS HEGO NDS/CES

'91 4.9, 5.0, 5.8 Fseries w/o E4OD


fuel pump relay KS PSPS ACT pwr to sensors EGR posn feed EEC data + EGO fuel sensor GND canister purge solenoid

'91 4.9, 5.0, 5.8 Fseries w E4OD


fuel pump relay KS PSPS ACT pwr to sensors EGR posn feed EEC data + EGO

'91 7.3 diesel Fseries w E4OD


Fuel pump Knock sensor

Description

Power steering pressure switch Air charge temperature pwr to sensors Reference voltage EGR valve position sensor Heated exhaust gas oxygen sensor Neutral drive switch (automatic)

fuel sensor GND man'l lever pos or clutch canister purge solenoid O/D cancel lamp O/D cancel lamp

EVR

EVR

EGR valve

EGR valve EEC to xmsn

EGR vacuum regulator solenoid DOL

SPOUT VPWR

SPOUT VPWR

SPOUT from TFI pwr rly to EEC

SPOUT from TFI pwr rly to EEC electronic pressure ctl

tach feed electronic pressure ctl dedicated GND

Spark out timing control

pwr rly to EEC Vehicle power

40 41 42 43 44 45 46 47 48 49 51 52 53 54 55 56 57 58 59 60

PWR GND

PWR GND

dedicated GND

dedicated GND

Power ground

xmsn O/D switch xmsn O/D switch xmsn oil temp ACD MAP SIG RTN TPS STI HEGOG AM 1 SS CCO WAC coast clutch sol PIP VPWR INJ 1 INJ 2 PWR/GND PIP VPWR INJ 1 INJ 2 PWR/GND PIP from TFI pwr rly to EEC INJ 1 INJ 2 dedicated GND PIP from TFI pwr rly to EEC INJ 1 INJ 2 dedicated GND dedicated GND coast clutch sol Profile ignition pickup pwr rly to EEC Vehicle power Injector bank 1 Injector bank 2 Power ground MAP SIG RTN TPS STI HEGOG A/C demand MAP feed sensor sig rtn TAPS A/C demand tach retn MAP feed sensor sig rtn TAPS MAP feed TAPS EEC to test conn #1 Manifold absolute pressure Throttle angle position sensor Self-test input Heated EGO sensor ground Air management solenoid 1 xmsn throttle valve sol #1 clutch sw Converter Clutch Overide sensor sig rtn Signal return

EEC to test conn EEC to test #1 conn #1 fuel sensor GND thermactor dump valve fuel sensor GND thermactor dump valve xmsn throttle valve sol #1 clutch sw

Table 16: ECM CABLE PINOUT

EEC-IV Technical Notes: Hardware

21

last edited: 9/29/98

Eectch98-Part2.fm

Technical Notes on The EEC-IV MCU

SOFTWARE
Compiled by Tom Cloud <cloud@peaches.ph.utexas.edu> (font is Courier New)

THE BASICS
The EEC-IV original objectives included "calculating all required engineering command values and output the required real time commands for spark timing, exhaust gas recirculation valve positioning and for turning fuel injectors on or off in a sequentially firing configuration, in a total time of 2.5 milliseconds or less." EEC-IV programs are 57k in length and EEC-V programs are 114k and they both begin with: FF FA NOP DI (64k) and V5 (32k). The EEC-IV V5 is the only case is in a single chip (32k). Early Ford models (1990file) the board uses 57k only (the maps are in the processor inside the board makes the right address-

For EEC-IV there are 2 types V2 where all the software and data 1993). For EEC-V (114k source 2nd part of the source) and the ing function.

The EEC-IV tables can be located by looking at the cal pointers (located somewhere in the 30 or 50 bytes of EPROM after 2000). The table segment addresses are in there. Another helpful hint is that Ford likes the binary point method of scaling.

INTERNAL DIAGNOSTICS
Two types of diagnostics are performed by the EEC (this was written for early 80s model units so it may be expanded now). They are On-Demand and Continuous diagnostics. On-Demand is conducted during key-on/engine-off and during engine running modes to permit the microprocessor to test itself. Continuous, as the name implies, is on-going whenever the system is in operation. Beginning in the latter part of 1983, the EEC-IV began to remember conditions found during continuous testing, even after the key is turned off with a special custom memory chip called Keep Alive Memory (KAM). The KAM chip, which contains 128 bytes of read/write memory, is powered by a separate low current connection to the vehicle battery. Faults, even intermittent ones, are recognized and stored away for recall during dealer service.

FUEL CONTROL
There are two basic methods of fuel delivery: throttle body injection and manifold injection, and the methods of determining how much fuel to be delivered is determined using speed density, air volume or mass air techniques. The volume or mass air approaches require sensors to determine those values. The Air Flow sensor used in production EFIs typically compensates for temperature and density changes in the intake air mass, then the oxygen sensor is used to fine tune the mixture. Almost all use barometric compensation in one form or another. Some systems take a barometric reading from the MAP sensor after the ignition key is turned on, but before the engine starts, and store this as a reference. This can also be updated at WOT, since manifold pressure is essentially = barometric pressure at this point (with
EEC-IV Technical Notes: Software

22

last edited: 9/29/98

Eectch98-Part2.fm

some flow related pressure drop). Some systems have a separate barometric sensor in addition to MAP. Some MAPs are not absolute sensors at all, but differential sensors, referenced on one side to the atmosphere. So as the atmospheric pressure changes, the MAP reference point changes as well. Some compensation is possible with the fuel pressure regulator, since it is usually referenced to manifold pressure and thus atmospheric indirectly. This helps regulate the pressure across the injector so the amount of fuel delivered is related to only the injector pulse width. Some systems have no barometric pressure compensation at all. The EEC does 4 point interpolation on all tables. There is a minimal number of cells in the fuel lookup tables. The EEC doesnt look up injector on time, it calculates the injector pulse width by looking at the desired Lambda and then, using the mass of air entering the engine and the injector size, it calculates the duty cycle needed to get the desired A/F ratio. (Lambda is an engineering term where stoich is 1, anything smaller than 1 is rich, anything larger than 1 is lean. To get A/F numbers from Lambda, multiply lambda value by 14.64. For example, an A/F ratio of 14.05:1 is a lambda of .85 lambda.) The ECU controls both the fuel mixture and the timing with the fuel mixture operating in either "open loop" or "closed loop" mode. Anything external to the EEC that tries modify the fuel mixture at points where the engine is in closed loop operation will cause the computer to attempt to compensate. Thats why trying to change the A:F ratio and "fool the computer" cause more problems than its likely to solve. Timing and WOT fuel settings arent closed loop functions, and can be changed without the computer trying to correct them. This is why units that connect between the cable and the ECU arent very effective at modifying fuel mixtures. Closed loop operation can sometimes be altered without problems. This has allowed some manufacturers to market cars and parts that are fully emissions legal (e.g. Kenne-Belle, Saleen, etc). After-market devices that go between the engine harness and the EEC interfere with closed loop. Software modules that connect to the service connector (Hypertech, Superchips, etc.) do not interfere with closed loop rather they can define new values for closed loop. The EEC will do whatever its told -- its a computer running a program and your data can be substituted for the factorys through the service port connector. The EEC cannot learn around a software module. Closed loop operation basically consists of a controller with a target A/F ratio, HEGO information as its feedback and the injectors as the main control mechanism. The factory target A/F ratio is 14.64:1, but this can be changed. Approximately 900 items can be changed or logged in a 93 5.0 Mustang. For example, during a shift, the EEC might look at spark, load, TP, fuel, and transient fuel. By logging this data, you can tell exactly where in the spark tables the EEC is travelling and tune just those cells. Most people would normally tweak the whole curve down or try and tune in areas the EEC isnt even looking at. With data-logging, you can see exactly where its pulling its data from. Examples of some of the functions controlled by the EEC are: A:F ratio in closed loop, transient fuel, EGR, Canister Purge, Thermactor, adaptive control system, control of OBD-I and OBD-II testing (on/off/change test values...), fuel, spark, MAFs, VE tables, injectors, rev limits, speed limits, electronic transmission control, and lots more. If you have a later car (91 or newer), there is an integrated controller module (ICM) (12B577 basic #) located in the engine compartment. It is a black metal box about 8"X6"X1.5" and runs the cooling fan, the fuel pump, and the EEC power.
A contributor wrote:

"Ive been hacking away at the Taurus code, and I think I have 23
last edited: 9/29/98

EEC-IV Technical Notes: Software

Eectch98-Part2.fm

most of the code broken down into chunks. It looks as though Ford calculates AIRFLOW from the speed-density calculation, then re-calculates AIR MASS PER CHARGE from it. Im having a hard time figuring out the spark timing algorithms, probably half way through the PFE EGR system, and Ive looked at the O2 system. The adaptive learn stuff is weird. Ive looked briefly at the self-test. The timer scheduler is very weird. They ran out of HSO slots by the looks of things, so they wrote some clever code to get around that."

IGNITION AND TIMING CONTROL:


The EEC only sees one Crankshaft Position Sensor signal, but where it comes from depends on the age of the EEC. Early EECs used a sectored wheel in the distributor which produced a square wave of frequency of Number-Cylinders per 2-revs with a nominal 50% duty cycle unless SEFI was used whereupon there was a "short" tooth. The spark was output by a TFI unit. Later and perhaps all current EECs, including the EEC-V, utilize a 36-1 tooth wheel for CPS which is pre-processed by a unit known as the EDIS (Electronic DIStributor). The EDIS converts the 36-1 into a 2 pulses/rev 50% duty cycle square wave which is then fed into the EEC to be used for RPM and injector timing calculations. The EEC sends a PWM signal to the EDIS defining the spark advance required, and the EDIS unit then times out the signals to the coils (wasted spark). This gives a more accurate spark delivery as the EDIS has access to timing data which is updated every 10 crank degrees whereas the EEC only gets timing data every 90 degrees. The EEC gets one and only one timing signal from the TFI unit. It is called the PIP (Profile Ignition Pickup). The PIP signal is 45 - 55Hz @ 1000 RPM, for 4, 6 and 8 cylinder engines and, with the exception of SEFI, has a duty cycle of 50%. SEFI uses Signature PIP where the #1 vane on the PIP reluctor is roughly 35% duty cycle and the rest are roughly 50%. The EEC uses this to detect cylinder #1. On a stock car, the leading edge of the PIP signal is @ 10 BTDC. The EEC controls the spark timing. The TFIs function at this point is to basically clean up the PIP signal and charge and fire the coil. The TFI module conditions the hall sensor output and sends it off to the EEC. The only delay is just propagation delay through the TFI electronics. The EEC sends out the SPOUT signal which starts the TFI modules charging the coil. Depending on what advance the EEC is looking for, the falling edge of the SPOUT can vary. The coil fires on the falling edge. Since the EEC knows where 10 BTDC of each cylinder is, it can calculate when to drop the SPOUT signal by using timers. The MCU uses the previous PIP value to determine where the crank was. The TFI module can handle acceleration rates of up to 250 HZ/sec. Another function of the TFI modules is to provide LOS spark (limp mode). If the TFI detects a loss of SPOUT, it will generate its own SPOUT to coincide with the rising edge of PIP (10 BTDC...assuming you havent moved the distributor). To determine timing values, the EEC uses crank position (CPS), engine temperature (ECT), air-charge temperature (ACT), throttle position (TPS), EGO data and CylinderID to name the significant ones. Its relatively easy to calculate the spark required for optimum power from these, but the compromises made to meet emissions and driveability complicate matters. The "TFI" (EDIS) units are all very similar. The differences are in the EECs which, though electrically similar, are totally different in terms of code and calibration content. The EDIS gets the required spark advance from the EEC and, using the regularly updated crankshaft position, determines the ignition firing time. The return from the EEC to the TFI module (SPOUT or SPark OUT) is the timing inforEEC-IV Technical Notes: Software

24

last edited: 9/29/98

Eectch98-Part2.fm

mation and has the same specifications as PIP. the PIP does 2 things:

What was gleaned from this is that

1) It lets the EEC know how fast the engine is turning (frequency alone). 2) It gives a base signal to be sent back to the TFI after being delayed a bit. This delay or phase change (relative to the PIP) is what lets the EEC control timing. But, indirectly, the TFI is doing most of the work. The return signal from the EEC to the EDIS is unrelated to the PIP. cates to the EDIS unit the amount of spark advance required. It purely indi-

Knock Sensor
It looks like the SES/STO line is used to set the knock sensor threshold by pulsing the line to control the knock threshold. This only applies to systems using knock sensors. Does anyone know of any other rogue use of the STO line? If yes, does anyone have another suggestion on a line to use to sneak data out on? I am assuming that the EEC everyone is concentrating on does not have a CART like the Taurus one does.

LIMITED OUTPUT STRATEGY (LOS) OPERATION


The CPUs watchdog timer provides pulses on pin 18 (J2-15) which periodically retrigger multivibrator IC7 (74001MC) on the daughter PCB. If the CPU does not retrigger the multivibrator within a time interval specified by the time constant of C18 & R52, then IC7-7 goes high, thereby enabling LOS operation. PIP inputs then trigger the second half of IC7 and produce injector output pulses at IC7-10. The width of these pulses is defined by the time constant of R46 & C17. IC7-7 enables the preset LOS inputs of IC4 & IC8, and selects the fixed width injector pulses produced by IC7. IC1-2 (70002BB) disables IC3 & IC6 (71001FB). The resulting outputs are as follows: Self test output Injector banks 1 & 2 Fuel pump relay pin # 52, Q17 EGR vacuum regulator solenoid pin # 53, not populated Idle speed control solenoid Air management #1 Air management #2 pins 31,32,34,35,54,55 All inputs are ignored. IC1 senses VPWR and enables LOS operation if VPWR is below acceptable level. ON fixed pulse width, triggered by PIP ON OFF OFF OFF OFF OFF OFF OFF

FUNCTIONS / SCALARS / TABLES


These are the known parameters used in the EECs engine management algorithms and the search is continuing for others. Not all of these are used in every EEC applicaEEC-IV Technical Notes: Software

25

last edited: 9/29/98

Eectch98-Part2.fm

tion and there are likely to be others that have yet to be found. The actual memory locations, where known, are listed for the A9L.
Dependent Variable
EEC Load Scaling MAF Transfer WOT Spark Advance WOT Spark Advance WOT Spark Advance Accelerator Enrichment Multiplier WOT Fuel Multiplier Open Loop Fuel Multiplier Spark Advance Spark Advance Spark Advance Rate Min Low Speed Dwell Min High Speed Dwell Maximum Dashpot Clip Sea Level Lugging O/L Fuel Multiplier Altitude Lugging O/L Fuel Multiplier Crank Fuel Pulse Width Multiplier Cranking Fuel Pulsewidth Injector Offset vs. Battery Voltage Open Loop Fuel Multiplier Dashpot Decrement Rate WOT Fuel Multiplier Part Throttle Spark Advance Closed Throttle Open Loop Fuel Multiplier Altitude Fuel Adjustment Cranking Fuel Transmission TV Pressure Torque Converter Lockup Upshift Speed Downshift Speed Idle Airflow ECT TP TP TP TP

Independent Variable
Raw Load MAF Voltage RPM ECT ACT TP - A/D Counts RPM ACT ACT Barometric Pressure RPM Battery Voltage Battery Voltage RPM RPM RPM Time in Crank Mode ECT Battery Voltage RPM Dashpot[lb/min] TP ACT

Function
Table Row Pointer Mass Flow Kg/hr WOT Spark Advance Deg BTDC WOT Spark Advance Deg BTDC WOT Spark Advance Deg BTDC WOT Fuel Multiplier Open Loop Fuel Multiplier Spark Advance [Deg BTDC] Spark Adder Deg Seconds/Degree Dwell / Coil Off Time [ms] Dwell / Coil Off Time [ms] Dashpot Clip [lb/min] Lugging O/L Fuel Multiplier Lugging O/L Fuel Multiplier Crank Fuel Multiplier Pulsewidth [ms] Injector Offset Open Loop Fuel Multiplier Decrement Rate [lb/min]

A9L
6CB2 6DE2 7504 7532 7540 7B80 7B48 74EE 7528 779C 7748 7760 7346 782A 7846 729A 787A 7B30 7DE8 732A

Accelerator Enrichment Multiplier 71C1

Table 17: EEC Functions

EEC SCALARS
Scalar
Injector Size Injector Slope Minimum Injector Pulse Width Accelerator Pump Multiplier Open Loop Fuel Multiplier Part Throttle Timing Adder Dwell Minimum Dwell Maximum ACT Minimum for Adaptive Control ACT Maximum for Adaptive Control Minimum ECT for Deceleration Fuel Shutoff Minimum RPM for Deceleration Fuel Shutoff Minimum Load (MAP) for Closed Loop Hi-load Timeout to Open Loop

A9L

Table 18: EEC Scalars

EEC-IV Technical Notes: Software

26

last edited: 9/29/98

Eectch98-Part2.fm

Scalar
Idle Speed Neutral Idle Speed Drive CID Number HEGO Sensors WOT TPS value EGR Multiplier EGR Type PIP Filter Half Fuel Rev Limit ON Half Fuel Rev Limit OFF Speed Limit A -- ON Speed Limit A -- OFF Speed Limit B-- ON Speed Limit B-- OFF Maximum Spark Retard Cooling Fan ECT HI/LO/Hysteresis Intake Manifold Volume Thermactor Presence

A9L

* 7C16 7A82 7A84 * 7A86 * 7A87 * 7A88 * 7A89

Table 18: EEC Scalars

Scalar Examples
Scalars for 86-93 Mustang from Calibrator Demo Injector Size (lbs/hr) Injector Slope Global Accel Pump Multiplier Gobal Open Loop Fuel Multiplier Global Injector Delay (Crank Deg) Closed Throttle Spark Adder (Deg BTDC) Part Throttle Spark Adder (Deg BTDC) WOT Spark Adder (DEG BTDC) Tip-in Spark Retard (Deg BTDC) Maximum Lo-Speed Dwell (OFF Time in mS) Maximum Hi-Speed Dwell (OFF Time in mS) ACT Minimum for Adaptive Control (Deg F) ACT Maximum for Adaptive Control (Deg F) Minimum RPM for Deceleration Fuel Shutoff Minimum Load (MAP) for Closed Loop Hi-load Timeout to Open Loop (Seconds) Idle RPM in Neutral Idle RPM in Drive CID Number HEGO Sensors WOT TPS Breakpoint (A/D Counts) EGR Multiplier PIP Filter (CPU Cycles/Crank Rev) Turn ON Half Fuel Rev Limit Turn OFF Half Fuel Rev Limit Maximum RPM (No Fuel) Turn ON 1st Speed Limiter (MPH) Turn OFF 1st Speed Limiter (MPH) Turn ON 2nd Speed Limiter (MPH) Turn OFF 2nd Speed Limiter (MPH) 19.64 0.0072494 0.40 1.00 0 0 0 0 0 0.50000 0.20000 100 200 149.75 .0050049 2 672 672 301.04 2 555 1 961 6100 6100 6250 127.5 127.5 127.5 127.5 94-5 Mustang Scalars from Calibrator Demo High Injector Slope (lb/hr) Low Injector Slope (lb/hr) Injector Breakpoint Min Injector Pulsewidth 19.641 28.8 1.0014e-005 0.0014

ACT Minimum for Adaptive Control (Deg F) -20 ACT Maximum for Adaptive Control (Deg F) 160 Global Spark Adder Max Degrees of Spark Retard Minimum Tip-in Spark (Deg) Gobal Open Loop Fuel Multiplier WOT TP Breakpoint (V) ECT to Turn ON HS Cooling fan ECT to Turn OFF HS Cooling fan ECT to Turn OFF LS Cooling fan ECT to Turn ON LS Cooling fan Min ECT to Allow Decel Fuel Cut-off Intake Manifold Volume Open Loop Idle Multiplier CID EGR Multiplier EGR Type (2=None) Thermactor Present (0/1 = NO/YES) Enable Stage 1 Speed Limiter Disable Stage 1 Speed Limiter Enable Stage 2 Speed Limiter 0 -15 5 1.00 3.0518 228 220 204 208 140 4 1 301.04 1 0 1 10000 10000 10000

Minimum ECT for Deceleration Fuel Shutoff (Deg F) 140

Table 19: Example Scalars from Calibrator Demo

EEC-IV Technical Notes: Software

27

last edited: 9/29/98

Eectch98-Part2.fm

EEC TABLES
Parameter
Accel Enrichment Fuel [lb/min] Startup Fuel [A/F Ratio] Base Fuel [A/F Ratio] Injector Timing [Crank Degrees] Load Injector Firing Order Base Spark [Deg BTDC] Altitude Base Spark [Deg BTDC] Injector Output Port Borderline Detonation Spark Borderline Compensation Borderline Compensation Borderline Compensation Acceleration Fuel Time Constant Exhaust Pulse Delay HEGO Amplitude HEGO Bias Engine Torque Engine Frictional Torque ECT ACT Lambda ECT ACT Lambda ECT ECT RPM Injector to Fire RPM RPM Injector Port Load Load Load

Variable
Throttle Rate [Deg/sec] ECT Time Load Load

Variable

A9L
01CB 7C40 7BF0 7160 71B9 7574 75C4 7614 71B1

Limp Mode Spark Table [Deg BTDC] RPM

Table 20: EEC Tables

A9L Constants & Locations


Below is a description of each parameter stored in the EEC computer -- so far as we know it. For a more detailed description of how the data is actually stored in the EEC, go to the section titled A9L Tables on page 39 and A9L Table Format Explanation on page 43. THROTTLE RATE DEG/SEC
15 200 1.5 1.5 2.0 4.0 5.0 12.0 21.0 33 1.5 1.5 2.0 5.0 8.0 14.0 23.0 48 2.0 2.0 3.0 6.0 10.0 16.0 26.0 63 3.0 3.0 4.5 8.0 12.0 18.0 28.0 77 4.5 4.5 8.0 12.5 16.5 26.0 31.0 90 8.0 8.0 12.5 17.0 21.0 30.0 34.0 110 12.0 12.0 18.0 25.5 27.0 38.0 39.0 125 18.0 20.0 29.0 34.0 45.0 55.0 56.0

E C T

150 100 50 30 0 -30

Table 21: Accel Enrichment Fuel [lb/min]


The Accelerator Enrichment Fuel Table provides an operation similar to the "accelerator pump" in a carburetor. It gives amounts of extra fuel to add based on how fast the throttle is being depressed and modifies that by the engine temperature. For the A9L, the table is located at 71CB hex, is 8 x 7 in size, the values being stored as unsigned, single byte values in a two binary point representation (i.e. the smallest resolution is .25 lb/min). To get the values below, the value of each corresponding byte will need to be divided by four or multiplied by .25. ENGINE COOLANT TEMPERATURE oF
-30 0 30 60 90 120 150 180 210 240

Table 22: Startup Fuel Ratio

EEC-IV Technical Notes: Software

28

last edited: 9/29/98

Eectch98-Part2.fm

45.00 35.00

0 1.000 1.250 1.625 2.250 2.750 2.875 3.375

0 1.25 1.500 1.625 2.125 2.750 3.625 4.125

0 0.875 1.125 1.500 2.125 2.375 2.625 3.000

0 0.500 1.000 1.375 1.875 1.875 1.875 1.875

0 0.375 1.000 1.250 1.875 1.875 1.875 1.875

0 0.875 1.250 1.375 1.875 1.875 1.875 1.875

0 0.875 1.250 1.375 1.875 1.875 1.875 1.875

0 0.250 0.875 1.125 1.250 1.500 1.625 1.375

0 0.500 1.000 1.375 1.875 1.875 1.875 1.875

0 1.000 1.250 1.625 2.250 2.750 2.875 3.375

T I M E

25.00 15.00 10.00 5.00 3.00 0.00

Table 22: Startup Fuel Ratio The Startup Fuel A:F Ratio Table sets the startup fuel mixture enrichment based on the engine temperature -- analogous to the choke function of a carburetor. The mixture is additionally modified by the time the engine has been operating. For the A9L, this data table is stored at 7C40. It is a 10 x 8 table with unsigned, single byte values stored in three binary point format (.125 resolution). To retrieve the information from the byte values, they must be divided by 8.
ENGINE COOLANT TEMPERATURE oF
-30 90 10.500 11.250 12.125 12.750 13.625 14.125 17.625 17.875 0 10.500 12.125 13.875 14.375 14.250 17.625 17.875 30 12.500 13.500 14.250 14.375 14.250 17.000 17.625 60 12.500 12.750 13.500 14.375 14.375 14.375 16.625 17.250 90 12.750 13.125 13.875 14.875 14.875 14.500 16.500 16.625 120 13.125 13.500 14.375 14.875 15.250 14.750 16.375 16.375 150 13.500 13.750 14.125 15.250 15.250 14.750 16.000 16.000 180 13.500 13.750 14.250 16.000 16.000 15.250 15.250 15.250 210 13.500 13.625 13.625 16.000 16.000 15.250 15.250 15.250 13.500 13.500 13.625 15.000 14.750 14.375 15.250 15.250

L O A D %

80 70 55 40 30 15 5

11.250 12.7500

Table 23: Base Fuel A:F Ratio Base Fuel A:F Ratio: ECT vs. Load. Located at 76F0 (for the A9L), it is a 10 x 8 table of single, unsigned binary values stored in three binary point format (divide by 8). RPM
L O A D % 420 420 380 352 352 352 352 352 420 420 380 352 352 352 352 352 420 420 380 352 352 352 352 352 420 420 380 352 352 352 352 352 420 420 380 352 352 352 352 352 420 420 380 380 352 352 352 352 420 420 420 400 352 352 352 352 464 464 420 400 352 352 352 352 464 464 464 400 352 352 352 352 464 464 464 400 352 352 352 352

Table 24: Injector Timing The Injector Timing Table is expressed in crank degrees and is modified by rpm and load. The A9L values are located at 7160 hex in a 10 x 8 table, each data value being one unsigned byte. The value stored has the two LSB places shifted off so that the binary value must be multiplied by 4 to recover the data (i.e. the minimum resolution is 4 crank degrees and, I suppose, the maximum value possible is 2048).
Injector to Fire
1 3 7 2 6 5 4 8

Table 25: Injector Firing Order


The Load Injector Firing Order Table is stored at hex 71B9 in the A9L and is the 302 EEC-IV Technical Notes: Software

29

last edited: 9/29/98

Eectch98-Part2.fm

firing order. It is an 8 x 1, one byte, unsigned binary value.


RPM 500 700 900 1100 1300 1500 2000 2500 3000 4000
23.50 27.25 27.25 27.25 27.25 27.25 27.25 27.25

26.50 31.25 31.25 31.25 O 38.00 39.00 32.25 32.25 A D 30 28.75 30.00 32.25 33.25 37.00 37.00 43.75 46.00 32.25 32.25 23 28.00 28.00 33.00 41.50 41.50 42.75 43.75 43.75 32.25 32.25

75 11.50 11.50 13.00 13.00 15.50 18.25 60 11.50 14.25 14.25 14.25 17.00 19.50 50 17.25 17.25 18.50 18.50 20.75 23.00 40 23.00 24.25 28.75 32.25 35.75 37.00

% 15 28.00 28.00 28.00 31.25 33.25 34.25 34.25 34.25 28.25 28.25
05 28.00 28.00 28.00 27.25 29.00 30.00 30.00 30.00 30.00 30.00

Table 26: Base Spark [Deg BTDC]

50 40 30 20 10 0

75 60 50 40 30 23 15

90 0 11 00 13 00 15 00 20 00 25 00 30 00 40 00

0 50

70

The Base Spark Timing Table is stored at 7574 (30068 decimal) as unsigned byte values. Divide by 4 to convert to decimal.
RPM 500
75 11.50 11.50 17.25 23.00 28.75 28.00 28.00 28.00

700
11.50 11.50 18.50 24.25 30.00 28.00 28.00 28.00

900
13.00 13.00 18.50 28.75 34.50 33.00 28.00 28.00

1100
13.00 13.00 18.50 37.00 42.75 42.75 32.25 27.25

1300
14.25 14.25 20.75 39.00 43.75 42.75 34.25 29.00

1500
17.00 18.25 23.00 39.00 41.5 43.75 35.25 30.00

2000
27.25 27.25 30.00 38.00 41.5 43.75 35.25 30.00

2500
27.25 27.25 31.25 37.00 43.75 43.75 34.25 30.00

3000
27.25 27.25 31.25 32.25 32.25 32.25 28.25 30.00

4000
27.25 27.25 31.25 32.25 32.25 32.25 28.25 30.00

60 50

O A 40 D 30
23

% 15
05

Table 27: Altitude Base Spark [Deg BTDC]


The Altitude Base Spark [Deg BTDC] table lives at 75C4 (30148 decimal) as one-byte, unsigned

EEC-IV Technical Notes: Software

30

last edited: 9/29/98

Eectch98-Part2.fm

values. Divide them by 4 to convert to decimal. RPM 500


75 9.25 9.25 9.00 16.00 23.00 25.00 28.00 28.00

700
9.25 11.50 10.25 16.00 24.25 26.00 28.00 28.00

900
13.00 13.00 11.50 16.00 23.00 30.50 28.00 28.00

1100
13.00 13.00 12.75 16.00 27.50 38.75 31.25 27.25

1300
15.50 15.50 15.00 18.50 35.75 40.25 33.25 29.00

1500
18.25 18.25 19.75 24.25 37.00 42.00 34.25 30.00

2000
23.50 23.50 25.50 31.25 38.00 43.75 34.25 30.00

2500
23.50 23.50 25.50 31.25 38.00 43.75 34.25 30.00

3000
23.50 23.50 25.50 31.25 38.00 43.75 34.25 30.00

4000
23.50 23.50 25.50 31.25 38.00 43.75 34.25 30.00

60 50

O A 40 D 30
23

% 15
05

Table 28: Limp Mode Spark Table [Deg BTDC]


The Limp Mode Spark Table [Deg BTDC] Table lives at 7614 (30228 decimal) as unsigned byte values that must be divided by 4 to convert to their real values.
0 0 0 0 2 2 2 2

Table 29: Injector Output Port Table


The Injector Output Port Table lives at (29105 decimal) for the A9L as unsigned bytes. Table Row Pointer
0 0 1 6 7 7

Raw Load
0 0.04998779296875 0.100006103515625 0.600006103515625 0.75 1.99996948242188

Table 30: Load Scaling The Load Scaling Function parameters for the A9L are located at 6C62. The table is 24 bytes in size, organized in a 2-byte by 2-byte unsigned, interleaved format. The X values (Load) must be divided by 32768 to convert them and the Y values (Row

EEC-IV Technical Notes: Software

31

last edited: 9/29/98

Eectch98-Part2.fm

Pointer) are divided by 256.


MAF Voltage 0 0 0 0 0.571044921875 0.75 0.884033203125 1.091064453125 1.181884765625 1.321044921875 1.468017578125 1.573974609375 1.69091796875 1.802978515625 1.889892578125 1.989013671875 2.154052734375 2.31591796875 2.449951171875 2.58203125 2.694091796875 2.909912109375 3.14892578125 3.35498046875 3.5439453125 3.885986328125 4.177001953125 4.443115234375 4.76806640625 15.999755859375 Flow kg/hr 10.75 10.75 10.75 10.75 10.75 14.75 18.75 25.75 29.00 35.25 42.75 49.25 57.50 65.00 71.25 79.00 94.75 112.25 127.25 144.00 159.25 192.00 233.25 274.25 315.00 394.25 470.25 548.75 659.25 659.25 MAF Transfer Function

Flow kg/hr 800 600 400 200 0 0 1 2 3 4 5 6

Table 31: MAF Transfer Function The MAF Transfer Function is located at 6DE2 for the A9L, is 120 bytes in length, unsigned, and is 2-byte/4096 X (MAF voltage) by 2-byte/4 (mass air flow in kg/hr).
RPM 0.00 1000.00 1800.00 2150.00 2600.00 3500.00 5000.00 16383.75 Advance 10.25 10.25 22.25 25.75 26.75 26.75 30.25 30.25

40 30 20 10 0 0 1000 2000 5000 6000

3000 4000 RPM Table 32: WOT Spark Advance vs RPM

The WOT Spark Advance vs. RPM function is located at 7504 hex for the A9L and is composed of 8 interleaved X-Y values, each 2 bytes in length, each unsigned and each in two binary point format (divide the value by 4 to get a resolution of .25). The advance is in degrees BTDC.

EEC-IV Technical Notes: Software

32

last edited: 9/29/98

Eectch98-Part2.fm

ECT -256 86 120 200 236 246 254

Advance 2 3 0 0 -2 -4 -4

Table 33: WOT Spark Advance vs. ECT The WOT Spark Advance vs. ECT Function is located at 7532 hex in the A9L EEC. An interleaved table of 7 one-byte signed X-Y values, the X values (ECT) are multiplied by 2 and the Y values (advance inn degrees BTDC) are divided by 4 to convert them.
ACT -256 -256 -256 150 240 254 Advance 0 0 0 0 -6 -6

Table 34: WOT Spark Advance vs. ACT The WOT Spark Advance vs. ACT Function is located at 7540 hex in the A9L in a signed, one-byte format for both the X and the Y interleaved values. The X value (ACT) is multiplied by 2 and the Y value (Advance in degrees BTDC) is divided by 4.
TP Enrichment (A/D counts) Multiplier 0 200 452 852 1020 1 0.953125 0.296875 0 0

Table 35: Accelerator Enrichment Multiplier vs TP The Accelerator Enrichment Multiplier vs. TP Function, located at 71C1 in the A9L, is a table of interleaved X-Y values each unsigned and one byte in length. To convert them to decimal, the X values (TP sensor in A-D counts) must be multiplied by 4 and the Y values (the fuel enrichment multiplier) must be divided by 128.
RPM 0 1600 2400 3200 3800 4400 6000 1 0.90625 0.96875 0.9453125 0.9765625 0.953125 0.9453125 Multiplier

EEC-IV Technical Notes: Software

33

last edited: 9/29/98

Eectch98-Part2.fm

RPM 16383.75

Multiplier 0.9453125

Table 36: WOT Fuel Multiplier vs RPM The WOT Fuel Multiplier vs. RPM Function parameters are stored at hex location 7680 in the A9L. They are unsigned, 2 bytes in length and are arranged in an interleaved format, with the X values (RPM) needing to be divided by 4 to convert them to decimal and the Y values (fuel multiplier) needing to be divided by 128.
Intake Air Charge Temp -256 -256 -40 0 76 254 Fuel Multiplier 0.640625 0.640625 0.640625 0.812500 1.000000 1.000000

Table 37: Open Loop Fuel Multiplier vs. ACT The Open Loop Fuel Multiplier vs. ACT Function parameters are located at 7B48. They are single byte values stored as alternating X and Y values. The X values (intake air charge temperature) are signed and have to be multiplied by two to convert them to decimal. The Y values (open loop fuel multiplier) are unsigned and have to be divided by 64.
Intake Air Charge Temp -256 -256 160 190 254 Spark Advance 0 0 0 -2 -2

Table 38: Spark Advance vs. ACT The Spark Advance vs. ACT Function parameters, for the A9L, are located at 74EE. It consists of single-byte signed values. The X values (intake air charge temperature) must be multiplied by 2 to convert them to decimal and the Y values must be divided by 4.
Barometric Pressure 0 23.500 26.500 27.750 31.875 Spark Adder Deg 12 4 4 0 0

Table 39: Spark Advance vs. BP The Spark Advance vs. BP Function parameters are located at 7528 and consist of signed, single-byte values. Divide the X values (barometric pressure) by 8 to convert them to decimal and the Y values (spark degrees to add to the timing) nneed to be divided by 4.
EEC-IV Technical Notes: Software

34

last edited: 9/29/98

Eectch98-Part2.fm

RPM 0 0 992 3008 4000 8160

Seconds/ Degree 2.0000 2.0000 2.0000 1.5000 1.0000 1.0000

Table 40: Spark Advance Rate vs. RPM The Spark Advance Rate vs. RPM Function parameters for the A9L are located at 779C, are one byte values, with the X values (RPM) being signed and needing to be multiplied by 32 to convert them to decimal. The Y values (seconds/degree) are unsigned and must be divided by 16.
Battery Voltage 0.0000 10.0000 12.0000 14.0000 15.0000 4095.9375

Dwell 589.75 589.75 524.25 393.25 367.00 367.00

Table 41: Minimum Low Speed Dwell Minimum Low Speed Dwell is a function whose parameters are stored at 7748 as unsigned 16-bit values. To convert them to decimal the X values (battery voltage) must be divided by 16 and the Y values (dwell / coil OFF time in milliseconds) must be divided by 4.
Battery Voltage 0.0000 10.0000 12.0000 14.0000 15.0000 4095.9375

Dwell 655.25 655.25 485.00 439.00 393.25 393.25

Table 42: Minimum High Speed Dwell The Minimum High Speed Dwell Function parameters are located at 7760. They are stored as alternating X and Y values in an unsigned, 16-bit format. To convert them to decimal, divide the X values (battery voltage) by 16 and the Y values (dwell / coil off time in mS) by 4.
Dashpot Clip (lb/min)

RPM

0.00 0.12011718750 500.00 0.12011718750 1500.00 1.00000000000 2000.00 1.60009765625 16383.75 1.60009765625

Table 43: Maximum Dashpot Clip


EEC-IV Technical Notes: Software

35

last edited: 9/29/98

Eectch98-Part2.fm

The Maximum Dashpot Clip Function parameters are stored at 7346 as unsigned, 16-bit, intertwined X and Y values. To convert them to decimal, divide the the RPM values by 4 and the dashpot clip values by 4096.
RPM 0.00 0.00 650.00 750.00 1200.00 1500.00 16383.75 Fuel Multiplier 1.000000 1.000000 1.000000 1.203125 1.203125 1.000000 1.000000

Table 44: Sea Level Lugging O/L Fuel Multiplier The Sea Level Lugging O/L Fuel Multiplier Function parameters are stored at 782A as unsigned, 16-bit numbers. To convert them to decimal, divide the X values (RPM) by 4 and the Y values (Lugging O/L Fuel Multiplier) by 128.
RPM 0.00 0.00 0.00 0.00 0.00 0.00 16383.75 Fuel Multiplier 1 1 1 1 1 1 1

Table 45: Altitude Lugging O/L Fuel Multiplier The Altitude Lugging O/L Fuel Multiplier Function parameters are stored at 7846 as 16-bit, unsigned words. To convert them to decimal, divide the X values (RPM) by 4 and the Y values (Lugging O/L Fuel Multiplier) by 128.
Time in Crank Fuel Crank Mode Multiplier 0.000 0.000 0.000 0.000 0.000 8191.875 1 1 1 1 1 1

Table 46: Crank Fuel Pulse Width Multiplier The Crank Fuel Pulse Width Multiplier Function parameters live at 729A as unsigned 16-bit words. Divide the X values by 8 and the Y values by 128.
Pulse Width (mS) 39.69140625 39.69140625 22.41406250 14.48828125 10.75390625 5.83593750

ECT -65536 -20 0 20 40 70

Table 47: Cranking Fuel Pulse width vs. ECT


EEC-IV Technical Notes: Software

36

last edited: 9/29/98

Eectch98-Part2.fm

ECT 150 180 65534

Pulse Width (mS) 2.35546875 2.04687500 2.04687500

Table 47: Cranking Fuel Pulse width vs. ECT The Cranking Fuel Pulse width vs. ECT Function parameters are stored beginning at 787A as 16-bit words. The X values (ECT) are signed and must be multiplied by 2 to convert them to decimal. The Y values (pulse width in milliseconds) are unsigned and must be divided by 256.
Battery Injector Voltage Offset 0 7.50000 5.5000 7.50000 6.0000 5.53125 7.0000 5.53125 8.0000 2.59375 9.0000 2.03125 10.0000 1.68750 11.0000 1.40625 12.0000 1.15625 13.0000 1.00000 14.0000 0.90625 15.9375 0.90625

Table 48: Injector Offset vs. Battery Voltage The Injector Offset vs. Battery Voltage Function parameters reside at 7B30 as unsigned, single byte values. The X values (Battery Voltage) have to be divided by 16 to convert them to decimal and the Y values (Injector Offset) by 32.
Open Loop Fuel Multiplier 0 0 0 1075.00 1100.00 16383.75 1 1 1 1 0 0

RPM

Table 49: Open Loop Fuel Multiplier vs. RPM The Open Loop Fuel Multiplier vs. RPM Function parameters live at 7DE8 as unsigned, 16-bit words. Divide the X values (RPM) by 4 to convert them to decimal and the Y values (Open Loop Fuel Multiplier) by 128.
Dashpot[lb/min] 0 0.0620117187500 0.3500976562500 0.4499511718750 0.6499023437500 0.7500000000000 Decrement Rate [lb/min] 0.003417968750 0.002929687500 0.001953125000 0.007080078125 0.044921875000 0.062500000000

EEC-IV Technical Notes: Software

37

last edited: 9/29/98

Eectch98-Part2.fm

Dashpot[lb/min] 15.999755859375

Decrement Rate [lb/min] 0.062500000000

Table 50: Dashpot Decrement Rate Function The Dashpot Decrement Rate Function parameters live at 732A as unsigned 16-bit words. To convert them to decimal, divide both the X values (Dashpot[lb/min]) and the Y values (Decrement Rate [lb/min]) by 4096.

Data Pointers
There are 8 pointers at 2022h:
V2020: DW DW DW DW DW DW DW DW DW L0108 L8C00 L8E5A L8FD6 L93A8 L9430 L97A8 L9A7E L9E5A ;2022 ;2024 ;2026....

Notice the byte at 2020h is 8 and there are 8 pointers. At each address there is a pointer to the next - a linked list...
L8C00: DW 08E5AH

functions/maps/scalars L8E5A: DW 08FD6H functions/maps/scalars L8FD6: DW 093A8H functions/maps/scalars L93A8: DW 09430H functions/maps/scalars L9430: DW 097A8H functions/maps/scalars L97A8: DW 09A7EH functions/maps/scalars L9A7E: DW 09E5AH functions/maps/scalars L9E5A: DW 09EA2H ;ORG09EA2H FILL0FFH,0015EH ;end

Idle Speed Constants


These are the idle speed locations for the A9L 5.0 stang MAF.
Parameter
idle in neutral idle in gear

Value
672 RPM 672

Address
704A 704C

Notes
0054H = 84 and 84 * 8 = 672

Table 51: A9L Idle Speed Addresses Conversion:


EEC-IV Technical Notes: Software

38

last edited: 9/29/98

Eectch98-Part2.fm

(Note that, in Intel format, the LSB is first, so its actually as "0054", and 5416 = 8410. Multiply by 8 to get 67210.

Speed Limiters
ROM addr 0x7A86 0x7A87 0x7A88 0x7A89 : : : : : Data FF FF FF FF

There are two speed limiters here, and an ON and OFF value (With hysteresis, I think. Which means once you hit the speed limiter you need to slow down to the off value before you can accelerate again) When data = FF the speed limiter is off, otherwise the conversion is as follows: 0FFH --> 255, then divide by 2 and you get 127.5 Not sure which is on and which is off. I think its Speed Limiter A: 0x7A86 ON; 0x7A87 OFF Speed Limiter B: 0x7A88 ON; 0x7A89 OFF The ONs and OFFs may be swapped! Maybe someone else can help.

Rev Limiter
Max RPMs seems to be PIP filter related! to the EEC group. Any thoughts here? Please post your ideas

At address 0x7C16 I have for data C103 (reverse bytes to get hi-byte first, 03C1). H03C1 --> D961 which I think is the PIP filter. When I cut that number in half, my rev limit is half, so it definitely affects the rev limit.

Half Fuel Limits


They arent used in the stang, but if you wanted a half fuel limit: ROM addr : Data 0x7A82 0x7A84 : 007D : 307F half fuel ON half fuel OFF

007D --> 7D00 (little endian, remember) H7D00 = D32000 divide by 4 to get 8,000 RPMS for ON 307F --> 7F30 (little endian, remember) H7F30 = D32560 divide by 4 to get 8,140 RPMS for OFF Not only is this programmed above the "MAX" limit, OFF is higher than ON.

A9L Tables
(Gary Anderson wrote) "Just so you guys remember where Tom got the data:"
a9l.v5.out "Accel Enrichment Fuel [lb/min]

EEC-IV Technical Notes: Software

39

last edited: 9/29/98

Eectch98-Part2.fm

"Throttle Rate [Deg/sec] vs ECT "table:29131,8,7,1,d4,0 :1.5,1.5,2,3,4.5,8,12,18 :1.5,1.5,2,3,4.5,8,12,20 :2,2,3,4.5,8,12.5,18,29 :4,5,6,8,12.5,17,25.5,34 :5,8,10,12,16.5,21,27,45 :12,14,16,18,26,30,38,55 :21,23,26,28,31,34,39,56 "end "Startup Fuel [A/F Ratio] "ECT vs. Time "table:31808,10,8,1,d8,0 :0,0,0,0,0,0,0,0,0,0 :1,1.25,0.875,0.5,0.375,0.875,0.875,0.25,0.5,1 :1.25,1.5,1.125,1,1,1.25,1.25,0.875,1,1.25 :1.625,1.625,1.5,1.375,1.25,1.375,1.375,1.125,1.375,1.625 :2.25,2.125,2.125,1.875,1.875,1.875,1.875,1.25,1.875,2.25 :2.75,2.75,2.375,1.875,1.875,1.875,1.875,1.5,1.875,2.75 :2.875,3.625,2.625,1.875,1.875,1.875,1.875,1.625,1.875,2.875 :3.375,4.125,3,1.875,1.875,1.875,1.875,1.375,1.875,3.375 "end "Base Fuel [A/F Ratio] "ECT vs. Load "table:31728,10,8,1,d8,0 :10.5,10.5,12.5,12.5,12.75,13.125,13.5,13.5,13.5,13.5 :11.25,11.25,12.75,12.75,13.125,13.5,13.75,13.75,13.625,13.5 :12.125,12.125,13.5,13.5,13.875,14.375,14.125,14.25,13.625,13.625 :12.75,13.875,14.25,14.375,14.875,14.875,15.25,16,16,15 :13.625,14.375,14.375,14.375,14.875,15.25,15.25,16,16,14.75 :14.125,14.25,14.25,14.375,14.5,14.75,14.75,15.25,15.25,14.375 :17.625,17.625,17,16.625,16.5,16.375,16,15.25,15.25,15.25 :17.875,17.875,17.625,17.25,16.625,16.375,16,15.25,15.25,15.25 "end "Injector Timing [Crank Degrees] "RPM vs. Load "table:29024,10,8,1,m4,0 :420,420,420,420,420,420,420,464,464,464 :420,420,420,420,420,420,420,464,464,464 :380,380,380,380,380,380,420,420,464,464 :352,352,352,352,352,380,400,400,400,400 :352,352,352,352,352,352,352,352,352,352 :352,352,352,352,352,352,352,352,352,352 :352,352,352,352,352,352,352,352,352,352 :352,352,352,352,352,352,352,352,352,352 "end "Load Injector Firing Order "Injector to Fire vs. "table:29113,8,1,1,1,0 :1,3,7,2,6,5,4,8 "end "Base Spark [Deg BTDC] "RPM vs. Load "table:30068,10,8,1,d4,0 :11.5,11.5,13,13,15.5,18.25,23.5,27.25,27.25,27.25 :11.5,14.25,14.25,14.25,17,19.5,27.25,27.25,27.25,27.25 :17.25,17.25,18.5,18.5,20.75,23,26.5,31.25,31.25,31.25 :23,24.25,28.75,32.25,35.75,37,38,39,32.25,32.25 :28.75,30,32.25,33.25,37,37,43.75,46,32.25,32.25 :28,28,33,41.5,41.5,42.75,43.75,43.75,32.25,32.25 :28,28,28,31.25,33.25,34.25,34.25,34.25,28.25,28.25 :28,28,28,27.25,29,30,30,30,30,30 "end "Altitude Base Spark [Deg BTDC] "RPM vs. Load "table:30148,10,8,1,d4,0 :11.5,11.5,13,13,14.25,17,27.25,27.25,27.25,27.25 :11.5,11.5,13,13,14.25,18.25,27.25,27.25,27.25,27.25

EEC-IV Technical Notes: Software

40

last edited: 9/29/98

Eectch98-Part2.fm

:17.25,18.5,18.5,18.5,20.75,23,30,31.25,31.25,31.25 :23,24.25,28.75,37,39,39,38,37,32.25,32.25 :28.75,30,34.5,42.75,43.75,41.5,41.5,43.75,32.25,32.25 :28,28,33,42.75,42.75,43.75,43.75,43.75,32.25,32.25 :28,28,28,32.25,34.25,35.25,35.25,34.25,28.25,28.25 :28,28,28,27.25,29,30,30,30,30,30 "end "Limp Mode Spark Table [Deg BTDC] "RPM vs. Load "table:30228,10,8,1,d4,0 :9.25,9.25,13,13,15.5,18.25,23.5,23.5,23.5,23.5 :9.25,11.5,13,13,15.5,18.25,23.5,23.5,23.5,23.5 :9,10.25,11.5,12.75,15,19.75,25.5,25.5,25.5,25.5 :16,16,16,16,18.5,24.25,31.25,31.25,31.25,31.25 :23,24.25,23,27.5,35.75,37,38,38,38,38 :25,26,30.5,38.75,40.25,42,43.75,43.75,43.75,43.75 :28,28,28,31.25,33.25,34.25,34.25,34.25,34.25,34.25 :28,28,28,27.25,29,30,30,30,30,30 "end "Injector Output Port "Injector Port vs. "table:29105,8,1,1,1,0 :0,0,0,0,2,2,2,2 "end "EEC Load Scaling "func:27826,24,2,d32768,0,2,d256,0 Raw Load:0,0.04998779296875,0.100006103515625,0.600006103515625,0.75,1.99996948242188 Table Row Pointer:0,0,1,6,7,7 "end "MAF Transfer "func:28130,120,2,d4096,0,2,d4,0 MAF Voltage:0,0,0,0,0.571044921875,0.75,0.884033203125,1.091064453125,1.181884765625,1.321044921875,1.468 017578125,1.573974609375,1.69091796875,1.802978515625,1.889892578125,1.989013671875,2.154052734375,2. 31591796875,2.449951171875,2.58203125,2.694091796875,2.909912109375,3.14892578125,3.35498046875,3.543 9453125,3.885986328125,4.177001953125,4.443115234375,4.76806640625,15.999755859375 Mass Flow Kg/ hr:10.75,10.75,10.75,10.75,10.75,14.75,18.75,25.75,29,35.25,42.75,49.25,57.5,65,71.25,79,94.75,112.25 ,127.25,144,159.25,192,233.25,274.25,315,394.25,470.25,548.75,659.25,659.25 "end "WOT Spark Advance vs. RPM "func:29956,32,2,d4,0,2,d4,1 RPM:0,1000,1800,2150,2600,3500,5000,16383.75 WOT Spark Advance Deg BTDC:10.25,10.25,22.25,25.75,26.75,26.75,30.25,30.25 "end "WOT Spark Advance vs. ECT "func:30002,14,1,m2,1,1,d4,1 Engine Coolant Temp:-256,86,120,200,236,246,254 WOT Spark Advance Deg BTDC:3,3,0,0,-2,-4,-4 "end "WOT Spark Advance vs. ACT "func:30016,12,1,m2,1,1,d4,1 Intake Air Charge Temp:-256,-256,-256,150,240,254 WOT Spark Advance Deg BTDC:0,0,0,0,-6,-6 "end "Accelerator Enrichment Multiplier vs. TP "func:29121,10,1,m4,0,1,d128,0 Throttle Position-A/D Counts:0,200,452,852,1020 Accelerator Enrichment Multiplier:1,0.953125,0.296875,0,0 "end "WOT Fuel Multiplier vs. RPM "func:31616,32,2,d4,0,2,d128,0 RPM:0,1600,2400,3200,3800,4400,6000,16383.75 WOT Fuel Multiplier:1,0.90625,0.96875,0.9453125,0.9765625,0.953125,0.9453125,0.9453125 "end "Open Loop Fuel Multiplier vs. ACT "func:31560,12,1,m2,1,1,d64,0 Intake Air ChargeTemp:-256,-256,-40,0,76,254

EEC-IV Technical Notes: Software

41

last edited: 9/29/98

Eectch98-Part2.fm

Open Loop Fuel Multiplier:0.640625,0.640625,0.640625,0.8125,1,1 "end "Spark Advance vs. ACT "func:29934,10,1,m2,1,1,d4,1 Air Charge Temperature:-256,-256,160,190,254 Spark Advance [Deg BTDC]:0,0,0,-2,-2 "end "Spark Advance vs. BP "func:29992,10,1,d8,0,1,d4,1 Barometric Pressure:0,23.5,26.5,27.75,31.875 Spark Adder Deg:12,4,4,0,0 "end "Spark Advance Rate vs. RPM "func:30620,12,1,m32,0,1,d16,0 RPM:0,0,992,3008,4000,8160 Seconds/Degree:2,2,2,1.5,1,1 "end "Min Low Speed Dwell "func:30536,24,2,d16,0,2,d4,0 Battery Voltage:0,10,12,14,15,4095.9375 Dwell / Coil Off Time [ms]:589.75,589.75,524.25,393.25,367,367 "end "Min High Speed Dwell "func:30560,24,2,d16,0,2,d4,0 Battery Voltage:0,10,12,13,15,4095.9375 Dwell / Coil Off Time [ms]:655.25,655.25,485,439,393.25,393.25 "end "Maximum Dashpot Clip "func:29510,20,2,d4,0,2,d4096,0 RPM:0,500,1500,2000,16383.75 Dashpot Clip [lb/min]:0.1201171875,0.1201171875,1,1.60009765625,1.60009765625 "end "Sea Level Lugging O/L Fuel Multiplier "func:30762,28,2,d4,0,2,d128,0 RPM:0,0,650,750,1200,1500,16383.75 Lugging O/L Fuel Multiplier:1,1,1,1.203125,1.203125,1,1 "end "Altitude Lugging O/L Fuel Multiplier "func:30790,28,2,d4,0,2,d128,0 RPM:0,0,0,0,0,0,16383.75 Lugging O/L Fuel Multiplier:1,1,1,1,1,1,1 "end "Crank Fuel Pulse Width Multiplier "func:29338,24,2,d8,0,2,d128,0 Time in Crank Mode:0,0,0,0,0,8191.875 Crank Fuel Multiplier:1,1,1,1,1,1 "end "Cranking Fuel Pulse width vs. ECT "func:30842,36,2,m2,1,2,d256,0 Engine Coolant Temperature:-65536,-20,0,20,40,70,150,180,65534 Pulse width [ms]:39.69140625,39.69140625,22.4140625,14.48828125,10.75390625,5.8359375,2.35546875,2.046875,2.04687 5 "end "Injector Offset vs. Battery Voltage "func:31536,24,1,d16,0,1,d32,0 Battery Voltage:0,5.5,6,7,8,9,10,11,12,13,14,15.9375 InjectorOffset:7.5,7.5,5.53125,3.53125,2.59375,2.03125,1.6875,1.40625,1.15625,1,0.90625,0.90625 "end "Open Loop Fuel Multiplier vs. RPM "func:32232,24,2,d4,0,2,d128,0 RPM:0,0,0,1075,1100,16383.75 Open Loop Fuel Multiplier:1,1,1,1,0,0 "end "Dashpot Decrement Rate "func:29482,28,2,d4096,0,2,d4096,0 Dashpot[lb/min]:0,0.06201171875,0.35009765625,0.449951171875,0.64990234375,0.75,15.999755859375 Decrement Rate [lb/

EEC-IV Technical Notes: Software

42

last edited: 9/29/98

Eectch98-Part2.fm

min]:0.00341796875,0.0029296875,0.001953125,0.007080078125,0.044921875,0.0625,0.0625 "end

A9L Table Format Explanation


(Bill Lawrance wrote)
Im putting this note in front of Gary Andersons recent post on tables for the A9L. I hope it helps in understanding them. Gary has done a great piece of work here. He deserves real credit for digging this out. Everything Ive added here I got from studying his post. This note describes how the tables displayed in the post are represented in the EPROM. I got this from reading the program. This is only useful or interesting if you want to see how this is done. Nothing in the original post or in this note tells how these tables are actually used, although their titles are descriptive. Neither are there any units on the axes of the tables, although their titles are also descriptive. There are 2 types of tables displayed. --------------1) Two dimension Tables --------------The first of the two kinds of tables is identified in the output with table in the third line of output for a table. For example, the first table listed is: "Accel Enrichment Fuel [lb/min] "Throttle Rate [Deg/sec] vs. ECT "table:29131,8,7,1,d4,0 :1.5,1.5,2,3,4.5,8,12,18 :1.5,1.5,2,3,4.5,8,12,20 :2,2,3,4.5,8,12.5,18,29 :4,5,6,8,12.5,17,25.5,34 :5,8,10,12,16.5,21,27,45 :12,14,16,18,26,30,38,55 :21,23,26,28,31,34,39,56 "end --The first line is the title of the table --The second line is "X-axis label vs. Y-axis label"

--The third line is decoded as follows: table 29131 8 7 1 -----identifies this as a 2 dimension table the decimal location of the table in the PROM (or 71CB hex ) the number of columns (X-axis) in the table the number of rows (Y-axis) in the table number of bytes for each value in the table

d4 -- the scale of the value, in this case divide by 4 to get lb/min of fuel that each entry represents. m is used in other tables to specify multiply each entry. 0 -- each entry is unsigned

From the binary: 0071C0 0071D0 0071E0 0071F0 007200 54 5C E0 30 38 40 48 68-78 98 DC 14 20 B4 10 14 18 20 32-44 66 88 08 08 74 06 06 08 0C 12-20 30 50 06 06 48 68 28 0C 08 70 30 12 0C 7C 42 20 12

88 54 32 20

9C 6C 48 30

Grouping into rows of 8 columns: 54 30 14 10 08 06 06 5C 38 20 14 08 06 06 68 40 28 18 0C 08 08 70 48 30 20 12 0C 0C 7C 68 42 32 20 12 12 88 78 54 44 32 20 20 9C 98 6C 66 48 30 30 E0 DC B4 88 74 50 48

EEC-IV Technical Notes: Software

43

last edited: 9/29/98

Eectch98-Part2.fm

Converting to decimal and dividing by 4: 21 23 26 12 ... 5 ... 4 ... 2 ... 1.5 1.5 2 1.5 1.5 2 28 31 34 39 56

3 4.5 3 4.5

8 8

12 12

20 18

The rows are stored last first, so reversing rows gives the table as displayed: 1.5 1.5 2 1.5 1.5 2 2 ... 4 ... 5 ... 12 ... 21 23 26 --------------2) Function Tables --------------The second of the two kinds of tables is identified in the output with func in the second line of output for it. For example, the WOT Spark Advance vs. RPM table is: "WOT Spark Advance vs. RPM "func:29956,32,2,d4,0,2,d4,1 RPM:0,1000,1800,2150,2600,3500,5000,16383.75 WOT Spark Advance Deg TDC:10.25,10.25,22.25,25.75,26.75,26.75,30.25,30.25 "end --The first line is the title of the table --The second line is decoded as follows: func 29956 32 2 d4 -- identifies this as a function type table -- the decimal location of the table in the PROM (or 7504 hex) -- the total number of bytes in the table -- the number of bytes in each X entry -- the scale of each X entry. In this case, divide each X entry by 4 to get RPM m can be used to specify multiply each X entry. -- each X entry is unsigned -- the number of bytes in each Y entry -- the scale of each Y entry. In this case, divide each Y entry by 4 to get degrees of Spark Advance m can be used to specify multiply each Y entry. -- each Y entry is signed 3 4.5 3 4.5 8 8 12 12 18 20

28

31

34

39

56

0 2 d4

From the binary: 007500 007510 007520 FF FF 79 00-20 4E 79 00 B0 36 6B 00 A0 28 6B 00 98 21 67 00-20 1C 59 00 A0 0F 29 00 00 00 29 00

Since each entry is 2 bytes long, group into pairs: FF 79 20 79 B0 6B A0 6B 98 67 20 59 FF 00 4E 00 36 00 28 00 21 00 1C 00 FF 00 4E 00 36 00 28 00 21 00 1C 00 FF 79 20 79 B0 6B A0 6B 98 67 20 59

Since this is an Intel ---> CPU, reverse bytes of ---> each integer. --->

EEC-IV Technical Notes: Software

44

last edited: 9/29/98

Eectch98-Part2.fm

A0 29 00 29

0F 00 00 00

0F 00 00 00

A0 29 00 29

Converting to decimal and dividing by 4 gives: 16383.75 30.25 5000. 30.25 3500. 26.75 2600. 26.75 2150. 25.75 1800. 22.25 1000. 10.25 0. 10.25 In this type of table, the X and Y values are interleaved and stored in reverse. So, rearranging gives the table as displayed: X-Values Y-Values 0 10.25 1000 10.25 1800 22.25 2150 25.75 2600 26.75 3500 26.75 5000 16383.75 30.25 30.25

DA1 Constants & Locations


The DA-1 EEC fuel table is at 7ABE, 10,8 size. throttle tables 7CE0,7D30,7F08, 10,8 in size. WOT ignition 7CC0, 4,8 size. Part

EEC-IV Technical Notes: Software

45

last edited: 9/29/98

Eectch98-Part3.fm

Technical Notes on The EEC-IV MCU

SENSORS
Compiled by Tom Cloud <cloud@peaches.ph.utexas.edu> (font is Courier New)

EGO
Can the HEGO respond quickly enough to monitor each cylinder during engine operation? Cylinder-by-cylinder HEGO function can sometimes be seen during testing on engine dynamometers, but only at certain points. HEGO response time is 300 to 1500 milliseconds for a delta Lambda step of 0.1, either rich-to-lean, or lean-to-rich. Driven into rich or lean saturation, the sensor can require several seconds to recover. Assuming best case 300 milliseconds response time, in a V8 firing 2 cylinders per crankshaft revolution with stereo EGOs, the highest RPM one could hope to discern individual exhaust pulses would be about 300. Getting this information from the HEGO into EEC is also made difficult by the low pass filtering on the HEGO inputs, which are typically -3dB at 1 to 20 Hz, application dependent. This is to filter out HEGO buzz, which is the rapid output oscillation that HEGOs produce when at stoichiometry. Another problem that cylinder-by-cylinder mixture correction would create is with closed loop control bandwidth: An engine is basically an air pump with a finite response time to external stimulus, such as moving the throttle plate. Lets say its about 1 second. Basic control systems theory says that if you put said air pump into a closed loop control system, the control system bandwidth must be slower than the air pump response time, else the system will hunt, or be unstable. With regards to lean operation with an O2 sensor, the O2 sensors output is not particularly useful far from stoich. The time-honored way of biasing the mixture is to vary the switch voltage threshold (in software), and to low-pass filter the O2 sensor signal (again in software) and try to keep its average to a calculated value. This can vary the mixture sufficiently to optimize the operation of a catalyst. A normal (heated or unheated) O2 sensor cannot tell you if the mixture is rich enough for best power or not. The O2 sensor just goes to RICH, and you cant tell whether you are at 9:1 or 14:1 from the sensor though in the 14 to 15:1 region you may get some indication. Typically, the system extrapolates from the highest load at closed loop fuel trim value and applies this same trim value when power enrichment is on. This simple method works because injectors tend to be linear. If, at some operating point, it takes an 8 ms valid injection time (take the offset of the injector away) for a 16:1 mixture, then a 16 ms injection time would, ideally, give you an 8:1 mixture. The L03 1989 Caprice (GM) uses a strategy called lean on cruise. This alternates five minute periods of operation at about 16.5:1 with one minute intervals of stoich operation. This allows the ECM to run lean most of the time, but correct for changes in conditions. Interestingly enough, the O2 voltage does not spike much when going from open to closed loop: the engines operating conditions dont change that much.

EGR
The EGR reduces pumping loss by reducing manifold vacuum. It does, however, lower NOx by reducing the concentration of O2 in the cylinder. In essence, it lowers the oxygen content of the air by some 10 to 15%. This added inert gas absorbs the energy from burning the fuel and oxygen, releasing it on the expansion stroke. It
EEC-IV Technical Notes: Sensors

46

last edited: 9/29/98

Eectch98-Part3.fm

would be equivalent to raising the nitrogen content of air from 78 or 79% up to around 82 or 85%. The more dilute oxygen tends to lower the combustion chamber temperature. The reverse is true when you shoot nitrous oxide into an engine. In that case, you raise the oxygen content of the air and, consequently, raise the combustion pressures and temperatures (and not incidentally, power).

ACT
This is snagged from the graph in the Calibrator demo program. To determine air temp you can measure voltage at the ACT (air charge temp sensor). Reference is 5.0 volts. 68 86 104 122 140 158 176 194 212 230 248 Air TempoF 50 Voltage 3.52 3.06 2.62 2.16 1.72 1.35 1.04 .80 .61 .47 .36 .28 Table 52: ACT Transfer Function

TFI / PIP
Normally, the distributor contains the TFI (Thick Film Ignition) module and a hall effect pickup with a vane stator. The PIP (Profile Ignition Pickup) Signal begins when the hall-effect timing pickup switch sends a signal to the TFI module. Modification by a schmitt trigger converts this signal to a logic compatible output that is then sent to the EEC, which is responsible for Early EECs used a sectored wheel (vanes) in the distributor with the number of vanes being equal to half the number of cylinders. Later EECs utilize a 36 tooth wheel, with a missing tooth for synchronization, whose output is pre-processed by a unit known as the EDIS (Electronic DIStributor). The EEC processes the PIP signal and subsequently feeds a properly advanced or retarded signal back to the TFI ignition module to fire the plug.

EEC-IV Technical Notes: Sensors

47

last edited: 9/29/98

Eectch98-Part3.fm

KNOCK SENSOR
(basic part number: 12A699)

part # Res. f color


E3AF-AA E3ZSF-AA E6TF-AA E5TF-AA 37TF-AA 5.4K 5.7K 6.45K 6.0K 9.5K BLK GRY BLK BLK WHT 5.8L 2.3L 2.9L 3.0L 4.9L

usage
Ford/Mercury (Turbo) Tbird Ranger/Bronco II Taurus/Sable, Aerostar Econoline/Bronco

thread
1/2-13 UNC M12 x 1.5mm-6g M10 x 1.5mm-6g M10 x 1.5mm-6g M10 x 1.5mm-6g

Table 53: Knock Sensor Data

Knock Sensor

VSS
VSS gets used for many things, even in the manual gearbag calibrations. 1. Used to drive coast-down strategies. EEC will use longer throttle dashpots if it sees a non-zero signal from the VSS at closing throttle. This prevents lift-throttle snatch, especially in lower gears and at lower road speeds. 2. Drives radiator fan strategies. Fan is usually turned off above 45 MPH unless coolant temp is above fan-on setpoint. 3. Cruise control on vehicles with the cruise control integrated into the EEC, instead of a separate electronic module.. The engine should run fine without the VSS. I have disconnected the VSS in my 89 SHO and 98 Contour V6 to get rid of the long dashpot. If the strategy doesnt see a VSS signal, it drops the throttle immediately, which puts ME in control of the shift rev-matching, not the bloody computer. The cruise control is separate from the EEC, but they share the same sensor. For a manual transmission MAF Mustang, the VSS is used to maintain an 1100 idle when coasting to a stop until you drop below ~8 mph. Ive known a few people who converted their speed density cars to MAF that had stalling problems when pushing in and holding the clutch at speed until the VSS sensor was hooked up. The speed density cars did not use the sensor. Im not aware of the sensor being used for anything else except on the 93 Cobra, where it was used to change the timing curve when above 100 something miles per hour.

AFM
Modern bypass MAFS have the best resolution in the first 40% of their total flow, with some resolution losses of very low flows at idle and just off-idle.
Raymond Brantley wrote:

1 kg/hr is about .0081 CFM. And this is at 20oC (68oF) at 1 atm. (sea level). A mass air meter is that; a MASS air flow meter, not a volume meter. The units make sense [Kg/hr], if youre an old time, red-blooded American engineer or scientist that would be [slug/hr] where 1 slug = 14.59 Kg. Here are the conversion factors for CFM to/from KG/HR. They are based on the Ideal Gas Law: KgHr = InHg * CFM * 36.2 / (TempF + 460) CFM = KgHr * (TempF + 460) / (InHg * 36.2)

EEC-IV Technical Notes: Sensors

48

last edited: 9/29/98

Eectch98-Part3.fm

InHg is barometric pressure. TempF is Temp in deg F. Heres some info for your V/E calculations. This is the info for an 89-93 Mustang V-8 stock MAF meter, mapping voltage to Kg/Hr. If you have an after-market meter calibrated for different injector size you can subtract these percentages from your voltage across the scale. 24 LB 21%, 30lb 37%, 36lb 48%. Or just 19 divided by whatever injector size the meter is calibrated for.

Airflow in Meter Kg/Hr Voltage


13.307 18.377 23.446 32.318 36.437 44.358 53.863 62.101 72.557 82.062 89.983 99.805 119.766 141.945 160.955 182.184 201.511 243.017 295.296 347.258 399.220 499.341 595.661 595.661 695.149 835.193 .57 .75 .88 1.09 1.18 1.32 1.47 1.57 1.69 1.80 1.89 1.99 2.15 2.32 2.45 2.58 2.69 2.91 3.15 3.35 3.54 3.89 4.18 4.18 4.44 4.77

Table 54: Mustang MAF Transfer Function If you have a frequency meter you can measure the BAP sensor, but they are different before and after 93.

Testing AFMs
To test a MAF, supply it with +12V and ground. The output will vary from roughly 0.25V to 0.5V at no flow, up to 4.75 to 5.00V at full flow. John Lloyd <john@anergy.demon.co.uk> sent the following MAF calibration tables "I calibrated an air meter the other day in the lab... between the hi and lo flow masters but it may be of use? Calibration of air meters with Ford AFM
EEC-IV Technical Notes: Sensors

A slight discontinuity

49

last edited: 9/29/98

Eectch98-Part3.fm

Vs=5.0 Tamb=19C 19-Mar-97 L/min

Lo meter
0 25 30 40 50 60 70 80 90 100 120 140 160 180 200 110 160 0

volts
1.113 1.113 1.113 1.113 1.113 1.113 1.262 1.463 1.824 1.882 2.262 2.515 2.63 2.83 3.014 2.106 2.629 1.113

Hi meter
200 250 300 350 400 450 500 550 600 650 200 400 200

volts
3.045 3.339 3.564 3.766 3.854 3.971 4.076 4.158 4.201 4.245 3.097 3.868 3.087

Table 55: MAF Calibration Below data came straight off a Ford Calibration of air meters with AFM Vs=5.00 Tamb=19C AFM1 AFM2 Bosch 0 280 200 025 Ford 86GB12B529-AA with ref 0 280 200 047 From 2.9i V6 using two off 19-Mar-97 29-Apr-97

L/min Lo meter
0 25 30 40 50 60 70 80 90 100 120

AFM1
1.113 1.113 1.113 1.113 1.113 1.113 1.262 1.463 1.824 1.882 2.262 0.2

AFM2

Hi meter
200 250 300 350 400 450 500 550 600 650 680

AFM1
3.045 3.339 3.564 3.766 3.854 3.971 4.076 4.158 4.201 4.245 2.75

AFM2
1.16 1.73 2.09 2.35 2.58

0.25 0.25 0.25 0.25 0.25 0.45

Table 56: MAF Calibration

EEC-IV Technical Notes: Sensors

50

last edited: 9/29/98

Eectch98-Part3.fm

L/min Lo meter
140 160 180 200 110 160 0

AFM1
2.515 2.63 2.83 3.014 2.106 2.629 1.113

AFM2
0.68 0.83 0.98 1.15

Hi meter
400 200

AFM1
3.868 3.087

AFM2

Table 56: MAF Calibration This MAF transfer function graph came from Mike Wesleys Calibrator demo.

EEC-IV Technical Notes: Sensors

51

last edited: 9/29/98

Eectch98-Part4.fm

Technical Notes on The EEC-IV MCU

EXTERNAL (SERVICE PORT) CONTROL


Compiled by Tom Cloud <cloud@peaches.ph.utexas.edu> (font is Courier New)

EEC MEMORY CONTROL


The EEC uses an 8 bit multiplexed address / memory bus (MB7:0) and three control lines for all memory I/O. Unlike the common Intel multiplexing scheme, there are only 8 I/O lines and 3 control lines total, but these are set up with the capability to be used very efficiently. Unlike conventional RAM and ROM that must have its addresses decoded externally and then be given a "Chip Select" signal, both the EEC RAM (typically an i81C61 24 pin DIP), and the EEC ROM (typically an i8763 24 pin DIP) have their addresses decoded internally. The memory systems efficiency comes from the fact that there are two internal address registers in the ROM, and three internal address registers in the RAM. The ROM and RAM each have a 16 bit Data Address Register (DAR) that is loaded with the required datas address in two chunks (8 bits at a time) from the MB bus. The neat trick is that they also have a second register that is a 16 bit counting register called the Slave Program Counter (SPC). The SPC register always mirrors the 8061s internal Program Counter (PC) register. As long as there are no program jumps, the 8061 only has to issue a command to retrieve the next program byte from memory, and the data appears, it doesnt waste time sending an address like most typical microprocessors. Both the i81C61 RAM and the i8763 ROMs internal address registers (DAR and SPC) are a mirror image of one another. If information is requested from the memory location pointed to by the SPC, the two memory chips check to see if the address is in their memory map. If the address is in one of the chips memory map, then the data at that location is output to the processor via the MB bus. The result of this scheme is that if the RAM and ROM are not matched sets, it would be possible to have RAM and ROM trying to drive the MB bus at the same time. This isnt going to happen when using the original EEC chips, but could cause problems if someone is using an improperly designed memory translator "CHIP" in the EEC. In order to "reprogram" an EEC, tuners have resorted to building "ROM DECODER BOARDS". What these boards do is translate between the EEC MB Bus and the typical "ROM" chips that are commercially available. These boards (in one form or another) have two 16 bit registers, one of which is a counting register that is used as the SPC, and the other is just a regular 16 bit "Latching" register that is used as the DAR. At any given time one of these two addresses is being fed into the standard ROM that the board contains. In addition to these two registers, there is an address decoding section that allows the ROMs outputs to be driven ONLY if information is being requested, AND the address falls within the original (EECs) ROMs address. The typical EEC ROM is mapped from memory location 0x2000, so there is also some "address swapping" that allows the standard ROM to begin its memory mapping at what looks like 0x2000 to the EEC. These "ROM DECODER BOARDS" have only three control lines to work with, the /STB, IT, and DI. These three lines are controlled only by the 8061 microprocessor, and not any of the other chips attached to the MB bus. /STB is used to tell the memory that it is time to "LATCH" the 8 bits of information on the MB bus (If the 8061 is driving the bus), or that it is time to

EEC-IV Technical Notes: External Control

52

last edited: 9/29/98

Eectch98-Part4.fm

put the next byte of data on the MB bus (if the MEMORY is driving the MB Bus). IT can be thought of as the "Instruction Transfer" line. What it really does is choose whether the 8061 is accessing the SPC (if IT is high) or the DAR (if IT is low). DI can be thought of as the "Direction Indicator" for the MB bus. If DI is high, then memory has the rights to the MB bus. If DI is low then the processor has the rights to the MB Bus.

(DAR - data address registerSPC - slave program counter) An example would be reading a memory location using the DAR. In a "NORMAL" memory system (one with an address and a data bus) if we were going to read a memory location we would: 1. Place the address on the address bus. 2. Output the memory "read enable" to "enable" the memory chip. 3. Read the information off of the "DATA" bus. On an EEC MB bus system we would follow the same pattern: 1. Write the DAR (give the memorys address register the address). a. Lower DI - this gives the rights to the MB bus to the 8061. b. Lower IT - this tells the memory system were using the DAR, not the SPC. c. Drive MB bus with low 8 bits of the address. d. Bring /STB low for a cycle - tells memory to latch the low address. e. Drive MB bus with high 8 bits of the address. f. Bring /STB low for a cycle - tells memory to latch the high address. At this point the memory system has our "ADDRESS" that we want to read. 7. Raise DI - This tells the memory system that it has rights to the MB bus.

This is the same as sending a "memory enable" or "memory read" signal. 8. Read the data off of the MB bus. a. Read the low byte off the MB bus. b. Bring /STB low for a cycle. c. Read the high byte off the MB bus. One note: The EEC uses a "16 bit" memory, so an address didnt have to be supplied for the 2nd 8 bits of data, but when using the DAR you must begin reading from an even address, and the odd address will be available the following /STB. If you use the SPC to read the memory, you can (in theory) just keep strobing and read the entire chip. Ive found that I can only "strobe" about 300 bytes of data out of the memory before it "clams up". Your results may vary.

MEMORY CONTROL FUNCTIONS


DI 0 0 1 1 0 0 1 1 IT 0 1 0 1 0 1 0 1 /STB 1 1 1 1 S S S S CPU SENDING ADDRESS TO DAR CPU SENDING ADDRESS TO SPC MEMORY SENDING DATA POINTED TO BY DAR TO CPU MEMORY SENDING DATA POINTED TO BY SPC TO CPU (USUALLY AN INSTRUCTION) CPU TELLING MEMORY TO "LATCH" DATA INTO DAR CPU TELLING MEMORY TO "LATCH" DATA INTO SPC (PROGRAM JUMP) CPU TELLING MEMORY TO "BRING UP" HIGH BYTE <--(DAR + 1) CPU TELLING MEMORY SPC = SPC + 1, AND PUT ON MB BUS Table 57: Memory Control Functions

EEC-IV Technical Notes: External Control

53

last edited: 9/29/98

Eectch98-Part4.fm

NOTE: "S" indicates a "STROBE" of the /STB line. /STB is active low, and is never low more than a single machine state. There are three machine states per processor "clock" cycle.

Service Port Adaptors


Most commercial add-ons use a 27c512 chip, and the processor on the board only switches to the outside from address E000 to FFFF (which is where the calibration area / maps are for the EEC V). The Superchips, Hypertech, and Wesley chipmaster ROM boards contain a PLD from Cypress. Small device - not very complex at all, not many gates. Easy to copy as no security provision on the Cypress parts if you have access to the full development kit (you can read it back) and then make more copies. The PLD on the Calibrator is much larger and uses an Atmel part. Its very fast and has lots of I/O pins and internal gates. From the size of the part, its either a complex job or hes using a much bigger part just to confuse people. Atmel parts also have a security bit that can be set that makes the part unreadable.

PLDs
The "simple" PLD devices today usually have what is called a macrocell associated with each output. The macrocell has an AND/OR array that is fed into a flip-flop. The output associated with the macrocell can be programmed to take either the output of the flip-flop or directly from the AND/OR array, so they can be either REGISTERED or COMBINATORIAL. The flip-flops can usually be configured as RS, Ttype, D-type, and on some, JK-type flip flops. As the devices get more complex, you can have buried macrocells that have no external outputs, but can be used to build state machines inside the part. Since the 8061 is using an extreme example of a multiplexed bus, the PLD has to use registered outputs. Actually, thats not entirely true. You can build transparent flip-flops from the combinatorial logic because the output of each of the macrocells is fed back into the device and can be used as an input as well. So you could do simple latching without registered outputs, but you also have to implement a counter for the 8061, so registered outputs are necessary. In the case of Wesleys cal-pak things, it gets a little more complex. He routed the output of the EPROM into the EPLD (or at least he used to), so the pins that are connected to the 8061 address/data bus have to alternate between inputs to the address latches and an output buffer from the EPROM.

EEC-IV / EEC-V FLASH MEMORY


Theres been a guess that to program the EEC-V flash memory requires use of the J3 BS0, BS3, ERASE and PROGRAM pins. To find the FLASH memory, look for a PLCC package, probably 32 pin, that should be a standard 28F010 12V write, erase/5V read Flash available from TI, Intel, AMD, and others. It might be labeled 81C65 or 81C62. Also, theres some evidence that theres a "transitional" EEC-IV about 1993 that used the EEC-V FLASH memory but still retained the EEC-IV connector. This could be a boon to the tuner, as no adapter boards would be needed - only a cable to the PC and the protocol and software to reprogram it. Investigation is underway to accomplish real scan tool type data to be retrieved via the STI and STO lines of the EECIV. Apparently, STI goes to an HSI port and STO
EEC-IV Technical Notes: External Control

54

last edited: 9/29/98

Eectch98-Part4.fm

goes to an HSO port. Currently, there is a piece of code that is added to the interrupt routine that allows sending an address to the EECIV via the STI line and then echoes out the result from the STO line. It needs two hooks into the EEC -- one for a periodic interrupt (for the STO data) and the other for the HSI interrupt. WARNING! The sensor +5 volts is the SAME as the CPU +5 volts. Any accidental connection of the +5 ref of the TPS sensor to the battery via a test light, and spitzensparken and poppencorken. The biggest problem I can see when re-calibrating an EECIV is that there is virtually no way of figuring out what it is up to. Perhaps a scan port patch would be useful? How I think you would need to do that is enable the EER, and modify a few bytes of Ford code to get a hook for ours. Then out of the STO you can get scan tool data like you see on a GM. The limitation here is someone needs to figure out the use of any interesting memory locations and the scaling factors. This means when you get data, the SES lamp flickers. I think J3 pin 12 MRESET and 22 TSTSTB are the ones to use with the pause pin to read the ROM from J3. You have the unit full on and in pause mode by putting a low on J3 pin 8 and then putting a low on pin 12 and releasing (to reset memory program counter I guess) and then keep strobing pin 22 TSTSTB low and reading MB after each strobe and it seems to be reading the ROM contents. It appears STROBE pin 21 is for reading and control from CPU but MSTROBE is for memory dump.
Another contributor wrote:

In my opinion, the whole memory was set up to be high speed, yet only 8 bits wide. A conventional computer has to use the bus to apply an address, and then another bus to read the data at that address. It appears that, in an EEC, the CPU can just request "the next program byte" -- as pointed to by the "Slave Program Counter" so there is no need to send an address. There is a second register, the "Data Address Register", which is in charge of the data. It, however, doesnt increment by itself. The advantage of having both of these registers is that one can read an instruction, download the address of some data thats wanted, read the data, and then read the next instruction WITHOUT SENDING AN ADDRESS FOR THAT NEXT INSTRUCTION. I still have to be able to load that Slave PC with another address though, in the case of jumps and interrupts and stuff like that. Im guessing that getting the high and low bytes of data is even easier than Im showing. Why else would they call it a "16K X 16bit ROM"? If you have to ask for the high and low bytes separately it would be more accurate to call it a "32K X 8bit ROM"

EEC-IV Technical Notes: External Control

55

last edited: 9/29/98

Eectch98-Part5.fm

Technical Notes on The EEC-IV MCU

EEC EFI MODIFICATIONS & UPGRADES


Compiled by Tom Cloud <cloud@peaches.ph.utexas.edu> (font is Courier New)

SD TO MAF CONVERSION
Information on MAF conversion sent to me by Bob Nell bnell@utk.edu

(This is specifically for 87-88 SD 5.0 Mustangs.) I started with a stock 88 Speed Density 5.0 LX and got the MAF sensor, bracket, tubing, EEC-IV and manual tranny from a wrecked 91 LX MAF 5.0. (The Cobra MAF is different than the GT/LX MAF in that,in the Cobra, both the EEC and the MAF have been recalibrated for 24# rather than 19# injectors. So, if using Cobra components, use a Cobra EEC.) The MAF connector was purchased from a dealer for about $10 and came with solder, shrink wrap and splicing instructions. If a complete harness is required, there are companies that sell used ones. You will need: Mass Air Flow meter calibrated for the injector size (using mismatched parts can cause part throttle detonation and drivability problems). MAF bracket and mounting screws (3). MAF 4-wire connector, wiring to go to the EEC connector and EEC connector pins for two of the wires. MAF ductwork -- the tubing that goes from the engine to the MAF, from the MAF to the air cleaner and then to the intake scoop. Some clamps will also be needed to hold it in place. Extra EEC connector pins for hooking up the VSS and FPM2 signals.

The first step will be to remove the old speed density computer from behind the kick panel on the passenger side. Remove the kick panel, the retaining screw on the lower right of the ECM, push the wires out of the way and then, using a 10 mm wrench, remove the ECM. There are unused female pins (sockets) in the harness end of the EEC connector. Seven of these will be needed to add the necessary inputs (it can be done with four, but its not recommended). Looking at the connector, there is a red "H" piece of plastic that needs to be popped out of the connector to allow the pins to be inserted/removed. It can be pushed out from behind (the wire side) then a small pick will be needed to allow the pins to be removed. To be added: 4 Inputs for the MAF. 2 Inputs from the VSS (if you dont already have cruise control, you will have to add a new speedometer cable with VSS and appropriate wiring). 1 Input from the Fuel Pump Relay. the speed control amplifier The amplifier is the yellowThere are also a couple of EEC that require swapping a are the TAB/TAD (thermactor

If cruise control is present, run the 2 VSS inputs to instead of routing wires outside the car to the tranny. ish plastic box located near the drivers left foot. pinout changes between the speed density and the MAF couple of pin positions - if its as remembered, they air bypass/diverter) pins. Attach these 4 wires from the MAF to the EEC
EEC-IV Technical Notes: Modifications/Upgrades56

last edited: 9/29/98

Eectch98-Part5.fm

Air Meter Pin Air Meter Pin Air Meter Pin is VPWR) Air Meter Pin #60) (this is

C-T/LB to EEC pin #9 D-DB/O to EEC pin #50 A- Red to EEC (splice into the existing red wire on pin #37) (this B- Black to EEC (splice this into the existing blk wire on #40 or PWR GRND)

Also, these changes must be made: Pin 51 must be moved to pin 38 on EEC Pin 11 must be moved to pin 32 on EEC

To hook up the VSS: VSS + must be hooked up to Pin #3 on EEC VSS - must be hooked up to pin #6 on EEC

The VSS signal can be taken from the VSS or it can be tapped off the speed control amplifier, which is located near the dead pedal, and is the yellowish box in the corner by the drivers left foot. The DG/W wire is VSS+ and the black wire is VSS To hook up the Fuel Pump Signal: Splice into the PK/BL wire that goes into the Fuel Pump Relay (located under the drivers seat on pre-93 Mustangs) and run it to pin #19 on the EEC.

I don't know if anybody will use these, but it's nice to have the pt#'s

Motorsport Harness's and Component Kits

Main Harness M-12071-C302

Engine Harness and Controls Package M-12071-E302 5.0/ HO & 5.8L Firing Order 1-3-7-2-6-5-4-8

Engine Harness and Controls Package M-12701-H302 5.0L Non HO Firing Order 1-5-4-2-6-3-7-8

Engine Harness & Controls Package Includes: Injector Harness & Intake Mounted Sensor Package( ACT,ECT,EGR Pos. Sens., EGR), along with O2 sens. harness

Sensor and Relay Package M-12071-D302

Includes (2) O2 sensors, BAP sensor, EGR, TIB, and TAB solenoids. Fuel, air

EEC-IV Technical Notes: Modifications/Upgrades57

last edited: 9/29/98

Eectch98-Part5.fm

conditioning, and EEC power relays.

Computer and Mass Air Meter Kit M-12071-F302 (Man. Trans.) M-12071-G302 (Auto. Trans.)

Includes MAF Meter, EEC-IV computer, MAF inlet and outlet hoses, and MAF meter mounting bracket

NOTES FOR TRUCK APPLICATIONS:


The 95 Mustang Cobra R, (351W) used an 80 mm Lincoln Mark VIII MAF and 24# per hour injectors. The injectors will easily support 350 HP and the 80mm MAF is a better choice than the 70mm, as you get to use more of its linear range, so fueling can be more accurate. To convert SD trucks with E4OD/AODE transmissions to MAF, some people use the CA 5.8 MAF/E4OD (F5TF-12A650-BYA). Mike Wesley says he uses the F5TF-12A650-HB (95 CA 5.0 MAF/E4OD) on a 750+ HP daily driver 415 stroker Lightning with a Vortech S trim. It runs open loop, has been reprogrammed, drives like stock, gets 17 MPG and will run low 10s at 130+ in the 1/4 mile and A/C and cruise work great. Both of these EECs are set to use 4.10 gears. If a smaller ratio is used, say 3.55, you could use the F5TF-12A650-GB. There are probably 15-20 EECs available to convert a SD (later model) to MAF (some of these may compromise the ability to stay emissions legal). If you have an early SD truck with AOD, re-wire to the Mustang EEC (Ford MotorSport sells this kit). Youll have to move/add quite a few wires, and you might not like the results if youre not able to re-calibrate the EEC (like the Pro-M low cost kit, Kenne Bell, LCA and Downs Ford come pre-re-calibrated). The engine shuts down at 85 MPH, shifting is fairly sloppy and too early (at least on a Lightning). All Ford EECs shift poorly -- except for the Lightning, which is only slightly firmer. To use the Mustang EEC on a truck with an E4OD/AODE, you would need to run two EECs in parallel. The Mustang EEC runs the engine, the existing truck EEC controls the trans. Pro-M sells a kit like this. As with any instrumentation and control system, poor or improper grounding of sensors can should be avoided. The TFI module seems to be the most susceptible to problems -- and especially when making a new or modified installation. The largest source of current-induced voltages in the grounding system is the starter current, with the alternator being the next, so every care should be taken to isolate the engine management circuit grounds from the starter current path. Noise generated by the alternator and by aftermarket CDI (including multi-spark units) ignitions can cause real grief with an EFI. This noise can be both radiated and developed across shared grounds so, in addition to proper grounding techniques, care must be taken to not run wires close to the ignition/coil wires and to provide shielding where necessary. Some recommend placing a capacitor at the supply for the CDI to absorb the transients it generates. This is a good idea, but keep in mind that, when capacitors are involved, larger is not necessarily better. A large, aluminum electrolytic capacitor will begin to become inductive (i.e. it stops working as a capacitor) sometimes at frequencies as low as 10 kHz. In actuality, one would
EEC-IV Technical Notes: Modifications/Upgrades58

last edited: 9/29/98

Eectch98-Part5.fm

be better off with 100 F capacitor with a .1 F disc ceramic in parallel with it. The larger capacitor is adequate to provide the long drinks the CDI pulls from the battery voltage, while the smaller disc ceramic works up to hundreds of MHz and will help suppress the very fast rise time voltage spikes that are the true source of the radiated noise. Also, keep in mind that the EEC stops working when the input voltage drops below about 8 volts -- another reason to keep a good battery and to not share power distribution paths with the starter. The starter and charging circuit current loop should not include the engine management ground current loop, and vice-versa. As much as possible, the ground current path for the alternator and the starter should be kept entirely separate from the ground current paths for everything else. The best arrangement would be a heavy (e.g. 2 AWG) ground wire from the battery negative to the engine block at or near the starter and a similarly large wire from the battery positive to the starter relay. The +12 volt power for the ECM and the accessories can be picked off at either the starter relay or directly from the battery terminal. The ECM/accessory ground should be taken directly from the battery negative. Note that steel and iron are poor conductors and that much of the ECM sensing circuitry uses the engine or chassis for grounds. To head off problems before they start, heavy, stranded copper wire ground straps are recommended between any component that has a sensor bolted to it (e.g. the intake or the block) and to the ground at the battery. Solid copper tubing can be run along the chassis and/or frame and bolted to it at several points to assure a good ground to even the remote fuel pump and sensor -- just remember that stranded welding cable should be used anywhere the conductor can vibrate, move or flex so it wont break over time. (If youre not sure about why this is necessary, measure the resistance from some sensors grounded case back to the battery ground and keep in mind that the voltage dropped across that same path is E = I * R. So, a resistance of only .1 ohm will have one volt induced across it if 10 amps were to travel through that path, and the resistances are often much higher than that.)

TUNING
(by Bruce Plecan with editing by Joe Boucher and then by me)

Introduction
This purpose of this document is to assist someone in the tuning stage of an Electronic Fuel Injection (EFI) project. It contains discussions about the monitoring equipment required and the methods and strategies for the actual tuning. The information is based on the experiences of tuning a GM EFI setup on a small block. However, the methods should be applicable to most any engine. This paper doesnt reveal the location of the maps and tables in the ecm software but it does discuss their functions. The maps and tables for some ecms can be found on the internet. For example, the Syclone/Typhoon and the Buick T-Type fanatics have found most, if not all, the needed information to alter the EFI systems for the extreme modifications on their cars. Look out, here comes a warning. You can really mess up an engine if you dont understand what is going on and are not careful and methodical about tuning your EFI setup. This is not lawyer gibberish, this is for real. You can turn that expensive, close tolerance machine into a pool of molten crap real quick. I personally know of a kid who had too much money and not enough smarts. In the early days of EFI, he bought an O2 sensor monitor and a device to alter the O2 feed back signal to the ECM. He didnt hook up the O2 monitor properly, started twisting the knob on
EEC-IV Technical Notes: Modifications/Upgrades59

last edited: 9/29/98

Eectch98-Part5.fm

the signal modifier, leaned the fuel mixture too much, and melted the pistons. It can be done! After all the time and effort you have put into achieving this stage, it would be a shame to ruin something because your enthusiasm carried you away and you tried to tune too fast.

What Is Being Modified


When tuning the EFI setup, the data controlling the fuel mixture and spark timing is being altered. Each engine type and setup will require a unique set of data to achieve its ultimate power and efficiency setup. The camshaft, intake manifold, head design, and exhaust system all influence the torque curve of the engine and therefore the fuel requirements. The spark advance plays into this also. The following section discusses the different tables found in some ecms.

List Of Tables
Tables, Maps, Switches seen or heard of: Main Fuel (VE or LV8); Fuel Enrichment WOT; Main Spark (rpm vs. kPa or gms/sec); Spark added WOT Idle Speed; IAC steps (by cool temp); WOT enable TPS %; TCC lock/unlock by road speed; TCC disable by TPS %; TPS Enrichment (sensitivity, quantity, duration); Injector constant; AFR % enrichment vs. Coolant temp; EGR temp enable; EGR enable % TPS; EGR timing correction table; EGR fuel correction table; Speed limited MPH; RPM Limiter; Degrees retard by knock sensor by MAP; Degrees retard by knock by rpm (WOT); Turbo Boost Control; All diagnostic malfunction disables. Not all ECMs use all these tables!! DISCUSSION OF TABLES The following tables are for a 3020 lb. car: Engine; AL headed (vette 58cc chamber), 355 CID SBC, 9.5:1 CR Cross fire intake; 2" butterflies, .25" lid spacer 90lb/hr injectors Cam specs; 270 Comp Cam, .470 lift 270 adv dur, 224 @.050 110 3.42 gears Tranny; 700R4, 2800 rpm non-lock-up stall Exhaust; Edelbrock TES manifolds, very low restriction cat, 3"single ex (Walker). ECM ; GM 1227747 (no internal mods, OEM v-8 netres [a resistor pack]) Some details are not mentioned (gotta keep an edge).

30 35 40 45 50 55 60 65 70 75 80 85 90 95 100
400 600 800 1000 1200 1400 1600 1800 2000 2200 2400 2800 3200 3600 0 0 -4 -6 -6 -6 -6 -6 -6 -6 -6 0 0 0 0 0 -4 -6 -6 -6 -6 -1 -1 -1 -1 0 0 0 0 0 -4 -6 -6 18 24 27 30 30 30 26 24 22 0 0 -4 -4 8 20 24 28 30 30 30 26 24 22 0 0 -2 0 10 20 20 24 26 26 26 26 24 22 12 12 12 12 14 18 18 22 22 22 22 22 22 22 16 16 16 12 14 14 14 17 16 18 18 22 22 20 16 16 16 12 12 12 12 12 12 16 16 18 20 20 16 16 16 11 11 11 10 10 12 14 14 18 18 20 12 12 12 8 8 8 8 8 10 12 12 17 18 18 8 8 8 6 6 6 8 8 8 10 12 16 18 18 8 8 6 4 4 4 8 8 8 11 12 14 18 18 8 8 4 4 4 4 6 8 8 8 10 14 16 16 8 8 4 4 4 4 6 6 8 8 10 14 17 16 8 8 4 4 4 4 6 6 6 6 10 14 17 16

Table 58: Spark Table (RPM vs Vacuum kPa)

EEC-IV Technical Notes: Modifications/Upgrades60

last edited: 9/29/98

Eectch98-Part5.fm

RPM 800 1200 1600 2000 2400 2800 3200 3600 Advance 0 0 0 1 6 6 6 6 Table 59: Power Enrich Spark (RPM vs. Added Spark Advance)

20 30 40 50 60 70 80 90 100
400 800 1200 1600 2000 2400 2800 3200 0 0 0 0 0 0 0 0 0 0 0 0 0 1 2 3 0 0 0 25 51 49 50 50 16 16 29 46 49 49 52 53 16 18 45 50 51 51 54 55 36 39 50 51 53 54 55 57 41 47 52 54 57 56 57 59 50 52 57 58 59 59 60 61 54 54 60 60 62 62 64 64 vs. RPM)

Table 60: Volumetric Efficiency

(MAP

RPM 0 400 800 1200 1600 2000 2400 2800 3200 3600 4000 4400 4800 5200 5600 6000 Add Fuel 10 10 41 40 41 41 39 37 35 35 37 39 41 41 31 16 Table 61: Volumetric Efficiency WOT Enable (RPM vs. Additional fuel factor) RPM 0 400 800 1200 1600 2000 2400 2800 3200 % TPS 35 27 26 25 24 23 22 21 20 Table 62: %Throttle Position Sensor for Wide Open Throttle (RPM vs. % factor) These tables are very different from the OEM setup. But, for this engine combination, it works. The items to note are the lean/retard overrun (high vacuum values when you lift your foot off the accelerator pedals at speed) areas. Glance at the spark table to see when the engine wakes up. Note that the VE table values can add up to over 100%. Also, because the values in the %TPS for full throttle table are low, and with the existing VE in the first table, the system will change the air fuel ratio to rich instantly. Might also note the funny timing under 2800 rpm. Remember the 2800 rpm stall converter. With this combo the engine can light em at will in 1st, and 2nd. The car runs in the 13s but you can see how mild the cam and engine combination is.

Tuning Tools
In order to know if your wonder toy is about to melt down on one end of the air fuel ratio spectrum or put a smile on an Arab Sheiks face on the other end of the spectrum, you need to monitor the fuel injection system and some of its sensors. Heres a list of tools: * Digital Volt Meter (DVM) - (10 meg ohm impedance) for monitoring the Throttle Position Sensor * Vacuum Gage - For idle and part throttle analysis; * Tachometer - If you dont know, youve got a lot of learning to do; * Performance analyzer - To give you an unbiased reference of the cars performance changes other than the uncalibrated seat of your pants; * Scan Tool - To know what values the ecm is using internally;

EEC-IV Technical Notes: Modifications/Upgrades61

last edited: 9/29/98

Eectch98-Part5.fm

* Oxygen Sensor Monitor - Usually a 10 element LED Display. (The 10 LED AFR Display, and Knock detector schematics are at the GN T-type tech area.)

O2 Sensors And Indicators


As clarification, this O2 discussion is about/for conventional V-8s, Small Block Chevy, Small Block Ford, Big Block Chevy, Big Block Ford. While there are probably numerous others, there are a bunch of VTEC types that this may not be accurate for. Monitoring this sensor will keep you from melting your engine.

From some personal notes from the early-mid 80s there were many 2 gas analyzers that went to market for the then pending inspections for CA. Here are some conclusions drawn from some GM training center notes and a Radio Shack engine book. First from a slip of paper, circa 83, that lists O2 sensor volts relative to AFR Air Fuel Ratio, and one from 2-3 years ago from Cyberdyne, who manufacturers a 10 led AFR Monitor. The voltages match i.e.: 1v=17:1; .3v=16; .5v=14.9 ; .7v=13.8:1; .9v=12.7:1. Also, going by the RS book are some differences in response time vs. temp, and differences in sensor voltage depending on load. So yes there are variables, and yes the results will vary with mounting locations, and loading. But for high performance tuning as an INDICATOR, there are no reservations on using one as a guide. The double check would be doing plug cuts. If you are working on a 20:1 AFR engine, then you would have to use a wide ratio O2 sensor, or if it was exposed to a limited amount of exhaust gas and needed heating and thermal compensation then you need the double wammy wide ratio O2 stuff. For what the average DIY will be attempting, a good ole GM single wire mounted in iron manifold, and a 3 wire used in tubular headers will work just fine. So while the MEs, and EEs discuss the merits of both for a lot of us just building the 10 LED O2 monitor like is shown in the GN T-type tech area will work fine (http://ni.umd.edu/gnttype/www/buick.html). Also, the GNs have a bunch of cars running 10s,11s, that regularly use unleaded with a heated O2 and have "fair results" (10s with A/C actually is better than fair in my book).

Where To Start
Hopefully, when starting with any custom ecm or drive train combination, youll have something to start with, and better yet at least an EPROM from the same engine series. If not, then well cover both anyway, again with the GM OEM, because thats what was experimented with. Regardless of what youre working on, you have to pick a spot to start with. This involves pulling numbers out of the hat to begin with. The more you do, the smaller the hat gets, because you can rule out some things.

Idle
A suggestion is start at idle. For a SBC the initial timing for the distributor is 6 degrees before BTDC. How do you setup 6d without a timing light? On GM style distributor there is a set of little arrows inside the distributor. On a V-8, 8 on the reluctor, and 8 on the sensor ring. Just line the marks up and tighten the distributor clamp. The engine fires when the arrows are ever so slightly past each other in the direction of rotation. The second you get to about 400rpm is when the engine starts running off your ecm control. Less than that and on a cold day the engine will windmill when its cranking. Fill in the 400-800 RPM areas of the timing map with
EEC-IV Technical Notes: Modifications/Upgrades62

last edited: 9/29/98

Eectch98-Part5.fm

16d (Table 1). Also, fill in the lower rpm VE tables (Table 3) with 30, and try to start the engine without grinding the starter too much. The engine will warm up enough to wake up the O2 sensor, look at the scanner, and see where the BL is, and IAC Counts. The IAC Counts are a vacuum leak. So they are critical to a decent idle. Now you have some idea of where the mixture is, and what the kPa is from reading the scan tool. From experience you cant run the same numbers everywhere at idle. On the high side of idle kPa go richer, i.e.; with an engine that idles at 60 kPa if it is 30 there, at 65-70 it would be 32, and at 50-55 28. Yes, the 30 is a lot but its easy to go lean, and clean up the idle, then having stall all the time, and having to wait for the prime shot to burn out. Next, lean the VE values (Table 3) down till the O2 is swinging (value moving back and forth through .45 volts), the IAC is less than 10, and you have a min idle speed. For the initial butterfly opening I cut a strip of paper 1/4" wide and set the throttle idle setting so the paper is pulls through the butterfly opening with a minimum of effort and without tearing. Now the engine starts and will idle. This is a good start.

Light Cruise
This section is on how to do light throttle cruising set ups, using GM ECMs. This is for an engine using a slightly hotter than stock cam, healthy ignition and assuming that some roughing out of the fuel timing tables have already been done. The objectives are: Advance timing as much as possible consistent with minimum throttle opening; and use just enough fuel to run 128 or slightly lower BL numbers. For monitoring the engine, a digital volt meter (DVM) is attached to the Throttle Position Sensor (TPS), a vacuum gauge is hooked up to the manifold (but this is almost redundant of the TPS), a scan tool is hooked up for looking at the Block Learn (BL) numbers, and a 10 element LED display is attached to the oxygen sensor. With this wired up it is easy to now start changing the timing of the 40 kPa areas of the fuel map by rpm for cruise. On a flat road with the car in top gear, find the cruise speed at 40 kPa and note the DVM signal from the TPS. Add timing and repeat the road test at the same TPS value. Observe whether the vacuum value is above or below the original signal. Repeating this procedure will reach a limit where the knock sensor will start retarding timing. Next, drop off as much timing going to the 20 side (overrun), which richens the O2 readings and helps to cut the fuel on overrun, so the car slows when you take your foot off the gas. On some of the OEMs you almost have to hit the brakes to slow the car. From the 40-50 kPa vacuum value, again depending on your car, drop off as little timing going toward 100 kPa (full throttle), as possible. Run enough fuel in the VE table so that when pulling slight grades the motor doesnt chug (love that technical language). Also use a minimum amount of timing for the WOT spark value. A suggestion is stay on the low side of the BL 128 at cruise so the engine is instantly smooth and pulling when the gas is nudged. There is no difference in MPG between this and 128. If you have the capability for pulse width modulation (PWM) of the EGR Id turn this off during the initial tinkering so that you dont chase too many items at one time. Just doing the spark and fuel can be an exercise in patience. Also, with a big cam just off idle and just as you go to light cruise at say 30-35 mph, you may have a dodo area (in this area of the PROM maps, BLs are lousy regardless of timing AFR). What is happening is the engine is starting to wake up, the intake tract length is starting to work, and the engine is reducing its self EGR. Pulling from 1600 rpm in high gear, smoothly from a roll might be the best performance test possible. Some engines just dont like to lug down to 1400.

EEC-IV Technical Notes: Modifications/Upgrades63

last edited: 9/29/98

Eectch98-Part5.fm

Perform the light throttle cruise initial tuning in whatever gear is 1:1, or less (overdrive). Doing the tuning while giving the engine the advantage of gearing might leave you having to do a major retune. On some of the EPROMs you can lower the TPS enable settings. If youre running an auto tranny watch it. If you have a throttle value (TV) cable sensing transmission you must have enough line pressure increase to keep from smoking the tranny to handle the extra HP at low TPS settings.

WOT
General Concepts Remember, this is from personal experience, and the example vehicle is the vehicle used in the light cruise tuning. DONT DO THIS WITHOUT ADULT SUPERVISION. In other words, be careful, patient and methodical. To review, starting with a GM ECM with initial programming set to 10-14 degrees WOT maximum retard. Set the decay rates slow. Set the total timing amounts to 30 degrees. Set the WOT AFR to 11.5. Hook up a scan tool, LED O2 sensor display, and performance analyzer. Now adjust the F/P so that you can drive at WOT. Watch the O2, as you drive (OK glance at it). After the pass is over, look at the knock counts. If the O2 sensor was plenty rich (all ten LEDs Lit), and no knock counts advance all timing 2 degrees and lean the WOT A/F mixture to 11.7 Repeat driving test. A few words about the last item, analyzing performance requires something self-triggering, and easy to use. A home-grown performance analyzer is described in Appendix A. Now adjust the F/P so that you can drive at WOT. Watch the O2, as you drive (OK glance at it). When the pass is over, look at the knock counts. If plenty rich (all ten LEDs Lit), and no knock counts, advance all timing step 2 degrees and lean to 11.7 Repeat driving test. Plenty of LED, and no knock counts, add 2 degrees more timing and lean the mixture to 11.9. Somewhere now youll start either slowing down, or tripping the knock sensor. ally the knock starts triggering between 2000-2600 rpm. Usu-

The WOT AFR stored in the prom can be a wide range of values depending on your injector sizing, and PSI. Remember this is an ECM calculation and has nothing to do with reality. During all of this do some plug cuts, and learn how to read the removed plugs. If the F/P is changed then the fuel VE values at part throttle in the prom tables will have to be adjusted. Some juggling back and forth between the values in the VE table and the WOT AFR will be expected. Now, the ecm has been told a huge lie. This means we didnt know where the injector constant lives. The TPS Enrichment (EFI talk for carb accelerator pump) location was unknown, so for this application huge injectors were used. The engine is running a 90#/hr injector, with an injector constant in the EPROM size of 65. This is not the best way to do this. But, by creative use of Fuel Pressure Regulators, and time consuming recalibration of the VE tables, the system was made to work, but some of the constants look really strange, i.e. WOT AFR of 13.5. The actual AFR is closer to 12.5 -- the 13.5 only exists in the ECMs mind.

EEC-IV Technical Notes: Modifications/Upgrades64

last edited: 9/29/98

Eectch98-Part5.fm

To achieve the EPROM files for this setup, burning 400 chips was not required to get it right, 400 chips were burned to get it PERFECT. More than likely 98% of the world would never notice the difference in the last 100+, and the first couple of 100 was figuring out how to do the above. PS When doing the above settle for the least amount of timing consistent with the best performance. Trying to run maximum timing results in hitting the knock sensor and having varying ETs. IF you run too much timing you may have to disable the knock sensor diagnostics because the car is so happy with yesterdays tuning, and today the ECM is using the OEM specs and cant run the diagnostics, and the fault codes get pinged. (This setup is that way)

Mild Performance Engines, Engine Swaps


Now things take a step up, tools are still the same, but now it would be nice to have a scan tool, With probably a different cam the operating range of the sweet spot of the engine has changed, or the weight of the vehicle has. This weight thing is not to be taken lightly (HOHO HAHA), just had to sneak a little humor in. A light car and/or one with higher numerically final drive gears will want a lot more fuel earlier, or more timing taken out sooner. So now youll have to have some control of the timing. But still if youre using a distributor, you can get by with just timing at cruise or WOT. If its a mild cam (and if youre doing this for the first time I would highly suggest you stay conservative). Now use your scan tool and look for the magic 128, try adding/subtracting two to four degrees here and there do the 4d to get a feel for things, and do not use any WOT testing when going 4 at a time.

Real Fire Breathing Hot Rods


(Things that go lump, lump, rump, rump at idle, have non-lock up converters, and spin tires in any gear less than overdrive.) This will require modifying such parameters as Main Fuel Table; WOT enrichments; Main Spark Table; WOT Spark Adders; TPS Enrichments (sensitivity, duration and quantity); Enable WOT TPS percentage settings; Cooling fan operation; and Idle speed. Having the right tools is essential here or the engine will do a basic China Syndrome Routine meltdown -- and it doesnt take long at WOT. A code scanner, a DVM, vacuum gauge, full time fuel pressure gauge (and isolator), and an air-fuel ratio meter (a DPM or an LED bargraph) are essential and it wouldnt hurt to have an audible knock detector. Ok higher compression, no big shakes Small chamber/AL Heads generally make a difference, for either less total timing, at WOT Aluminum Heads need more timing during light throttle cruise, non-lockup converter, more initial enrichment (due to less drivetrain inertia). There are several other considerations for the non-lockup converter - including the extra wear-and-tear on the TCC linings. Since more fuel will be needed earlier, the % TPS WOT enable must be lowered. At this level, the instrumentation requires constant attention to prevent damage. With EFI and knock protection, there is usually protection from things going wrong but, when things do go wrong, you cant forecast what the problem will be. Also, at this level, you might consider running a fuel separator, which is basically a large tank for the sediment to separate in, so there is no pressure drop due

EEC-IV Technical Notes: Modifications/Upgrades65

last edited: 9/29/98

Eectch98-Part5.fm

to a restricted fuel filter.

General Tuning Tips


(Abbreviations: WOT, wide open throttle; DVM, Digital Volt Meter; AFR, air fuel ratio; FP, fuel pressure; VE LV8 mixture; TPS, throttle position sensor, TCC; torque converter clutch) No matter what, save your original data!!.. Tinker with STOCK ENGINES, to get your feet wet. One of the easiest errors is to use too much air filter. Actually, the problem is getting the air to organize to flow through the throttle body. Having several hundred square inches of filtering surface area is fine, but having a huge volume of air sitting on top of the butterflies, can have its down sides. I.E. when the throttles snap open, it takes/can take a huge accelerator pump shoot to cover the delay in this column of air to get moving. If youre using an open element filter then try this. Assemble the air cleaner housing, and element as it would sit on the air horn. Measure the distance from the sealing ring portion to the lid, anything more than an inch is too much. Go to the hobby shop (say you had 3 1/4" dimension) Lets also say the air filter sealing ring was 5" in diameter. Youll need enough thin brass to make two rings, 3" wide and about 16" long to make a tube 5" in diameter, and 2 1/2" tall. The reason I say two is you have to experiment on the height, and that means going too far, which will ruin the first one. I havent found getting more than 1/4" close as necessary. To get involved all you need is the locations of the WOT enrichments, or the VE tables (TBI), or LV8 (TPI) in the EPROM tables. With the WOT enrichment/APR you can tune the FP till the cruise feels right, and then enrich WOT. If that doesnt work try leaning things down. Always remember, too rich and you buy spark plugs. Too lean and you buy head gaskets, exhaust valves, rings etc. Or tune the WOT, experimenting with the tables to even things out. Tuning cruise is just watching the DVM for the lowest TPS. On the Fuel tables changing things by 10% should make a noticeable difference. Again move just a couple at a time, till you get a feel for things. If youve only been driving high performance cars for a couple 100K miles, it might take some getting used to for what makes a change. If youve got a ton of time behind the wheel, and a lot of SCCA time, you might have a better sense of things, either way take your time. Sometimes a FP adjustment can make the engine respond perfectly. If the fuel pressure is increased, and the engine runs better, that means one thing, it was universally lean. Eventually youll reach a point when changing it doesnt seem to make much of a difference, and then performance falls off quickly. When addition fuel is added (more than what is needed) the ecm just leans things down, so the BL changes. When the engine goes to WOT enrichment it glances over at the BL and if its low (less than 128), then it will reduce the injector open time. If the goal is to richen WOT then you have to lean the tables down so the BL is right, or change the WOT AFR. Conversely, to lean out the WOT raise the VE table entries, or lean down WOT AFR. I have not read anything that says you cant run vacuum referenced fuel pressure regulators with TBIs, but the pressure output variance is usually too much. But, if you run a second fuel pressure regulator, you can trim this variance. This is the
EEC-IV Technical Notes: Modifications/Upgrades66
last edited: 9/29/98

Eectch98-Part5.fm

only way out of not being able to tune the accelerator pump features of TBI, since no commercial program Ive heard of allows this to be done. However, once you have things rather close you can try other chips from other applications, and put your tables on them. From the good old days, a big block always took more accelerator pump than a small block (hint). Again rich you buy spark plugs, lean its internal engine parts. For Spark, not enough timing, and you foul spark plugs, too much advance its internal engine parts. (too long, too retarded, overheating) If TPS enrichments arent changeable then try setting the VE high and low, (to try having different BLs), then this BL will start to work as an enrichment during TPS transitions. The reason this works is that the ECM will start moving the IAC counts around. When tuning remember the IAC is a vacuum leak. Less is better.

A Note About Timing


I have done a bunch of playing with timing especially at WOT, and lately have noticed that 2d less than triggering the knock sensor has had no effect on performance. In the past Id spent lots of time doing dyno work and many times the customer would wind up taking 2-4d out from where we had it. Please note this is in the early 70s, and we were using one we made, and were no where as sophisticated as they are now. Might mention this was also getting the AFR to correct within .2 volts at each timing spec. Try adding timing to the spark table, and remove a similar amount from the WOT spark addition. The same with the fuel table, and WOT enrichment. When you start getting close, change only one thing at a time, one thing only. Move two and things might seem fine but then 2 moves later everything takes a turn for the worse and you wont know where to start.

Maf System Differences


On a 89 vette there arent really the VE tables as shown before, my example was for a TBI which is a Speed Density. The computer knows from various sensors what is going on but has to calculate the air entering the engine, and then fine tunes it by using the O2 sensor. So you have to "give it a range" to estimate where to start these calculations, and based on that a set of look ahead tables for it to consider. Now, on an engine with a Mass Air Flow sensor the ecm is constantly being told how much air is being used, and with that known its a simple calculation for figuring the injector timing. So all it really needs is something for enrichment for acceleration, and something for WOT. Setting up a MAF is really easy to do compared to a MAP, if ya can get the WOT enrichments then you about have it all. Some tinkering on the timing might be nice. The listed items are so tightly wound together that I really dont know how to separate them for this document. And any one that has more to say on the subject I would invite to comment further. Again this is from my experiences on the subject matter, and my interruption of what others have told me, to correct difficulties that Ive experienced. The ecm is a marvelous thing, but it has no self generating logic, it just follows instructions. So it can be lied to and will never know the difference, and generates signals we humans use as a language to understand what the computer is doing. In other words if the computer is told to generate a WOT AFR of 13.5:1 it will do this using the information that is feed it. So this 13.5 is a calculation, and may or may not be an actual real world reading.

EEC-IV Technical Notes: Modifications/Upgrades67

last edited: 9/29/98

Eectch98-Part5.fm

On a multiport the injectors are calibrated at 3 bar (bar = 1 atmosphere = 14.7 PSI). Atmospheric pressure is 14.7 PSI. Absolute vacuum is 30 inches of mercury. A typical engine develops 15" of vacuum at idle referenced to a fuel pressure regulator referenced to the engine vacuum signal will change the FP approximately 7 PSI (30 in hg = 14.7 PSI). So the FP changes about 16% (7 psi/43psi) due to this vacuum ref. Depending on its initial flow characteristics the pressure regulator control can change some when it is vacuum referenced when installed in the car. Hence for calibration purposes the ecu value can be set for an injector size of 39 for an actual installed injector that is rated at 42. The less linear an injector is the greater this "error" will be. Also consider rising rate fuel pressure regulators, they will change the FP by a rate greater than the referenced change. I.E. on a turbo motor that generates 14 PSI boost a raising rate could generate a change of 28. This will help explain why, when the injector size is increased by 10%, you may/may not wind up changing the base injector width by 10% across the VE tables. This would be a good start, then again tune as necessary. It is your decision to start your WOT ranges at 13.5 or 14.7. Another tuner has had good experience using 14.7. If there is no change possible to these settings, than changing the injector constant will have a very profound effect. To quote from the OTC (Ottawa Tool Company) Scanner Manual "LV8, Filtered Load Variable (LV8)...in the filtered load variable mode, a number will be displayed that is proportional to the measurement of the amount of air being displaced per cylinder. The filtered load variable replaces the MAP sensor in some applications." So a MAF reading is grams/second, and a LV8 is a number that is a proportion. Therefore in a MAP set of calibration tables you have VE tables, and in a MAF you have LV8. Both have a table of TPS %s vs. RPM to enable WOT. Both have a correction for WOT enable, either a VE adder or % increase in injector timing.

Attachment A
There are some nice $100-$150 performance analyzer units out there, and they dont have to be perfect, just reliable. What I did was use the VSS and a Radio Shack Stop Watch. The VSS was tapped at the ECM and that was feed to a LM339. The stopwatch was taken apart and wires added for the power supply and across the start and stop buttons. The power wires went to an LED that was the ON indicator. The LED voltage drop of 1.5 was enough to run the watch even though it originally had a 1.6v battery (use a 100?fd at the input). The timer runs off a 7805 volt reg. Wire the on + off wires to a 4066. Wire each side of a 556 to be a monostable ON/ OFF pulse for the 4066. Going back to the 339. Tie its output to a counter set to divide by six. There are 3 pulses per tire revolution, so this will take two tire revolutions to start the timer, which helps reduce false triggering from wheel spin. At the reset connection tie that to a second divide by 10 and use that to trigger the first of the 556 for the start 4066. Wire the second divide by 10 to a third one, so that you have a total of divide by 100, and that will be the stop 4066/556 pulse. So now you have a timer that ignores the first 2 revolutions of the rear tire and then counts 200 revolutions to stop the timer figure 6 rolling diameter ya have a 600 portable drag strip in car that eliminates error due to wheel spin. (There is something wrong in the math, but paced out it was a little over 1/8 mile. That was 7 years ago.) Could be the last divide by 10 was actually set at 8. Breadboard a 555 pulse generator and burn it in. The watch should run to .001 ever time. No I dont have a schematic, and it was a cobble together, but it has been working for 7 years, and I

EEC-IV Technical Notes: Modifications/Upgrades68

last edited: 9/29/98

Eectch98-Part5.fm

not cutting it up to reverse engineer it till it fails. timer reset and register clear, but I forget.

Oh I did something for a

EPEC
The following information about SVOs add-on processor that augments the eec came from Super Fords web site: http://www.d-p-g.com/superford/april_97/eZ.htm EPEC consists of the EPEC processor module, a 6 ft. EPEC-to-PC serial interface cable, an EEC-IV module to EPEC module cable called a Wiring Harness Adapter, a short harness to connect to the Input/Output devices, several floppy disks containing the Windows calibration software and a small manual mainly for start-up use. $1395 and a lap-top or other PC is all thats required. Sam Guido at General Systems Research is the architect of EPEC, which is often referred to as the "Super Extender" by SVO insiders. It purportedly gives everyone the power to make the Mustang EEC-IV engine management do what you want. For the first time, fuel and spark functions are completely under the control of the operator. It is also a sophisticated data logger, so examining whats happening inside your EEC-IV system, like air temperature, air mass, rpm, etc., is now possible with great accuracy. SVO is pretty sure the EPEC module will work with any EEC-IV controlled engine, though its been tried only on the Mustang. Other applications may require that one modify the interconnecting harness supplied with the EPEC. Also, other differences in strategies among the various versions of EEC-IV, like EGR operation for example, may require one to toggle on or off certain functions at certain times, but what and when is something youll have to discover on your own. The EPEC is easy to install, thanks to the dedicated wiring harness, and should be operational as fast as you can access your EEC-IV computer and plug in the harnesses -- say 10 minutes. More time consuming will be wiring the seven input/output devices to the short EPEC harness. These are devices you select, such as nitrous triggers and timers, along with data logging hardware such as MAP sensors, thermocouples, etc. The EPEC instruction manual is not in a printed format but is delivered on floppy disks. A short, printed, manual of start-up instructions is packaged with each kit. EPECs Windows software offers simple operation. is plotted. Both table and graph information

EPEC works by turning off certain EEC-IV functions and substituting its own. This means EEC-IVs adaptive programming is taken off line, so the EEC isnt constantly battling the EPEC over engine control. Its ability to switch off most of EEC means it has far too much latitude with fuel and spark to remain even remotely within emissions guidelines so it will never be CARB exempted. For example, to work with the fuel system, you start with the Fuel heading, click and hold the mouse to reveal a menu, select from that menu and flip through the layers of fuel control. Highlight the function you want by clicking the mouse key, enter the parameter you desire and thats about it. Fueling is not handled by spelling out a specific injector pulse width, for example. Instead, there are 11 fuel control parameters available, each with a percentage scale you can easily dial in. The fuel control parameters are: Idle A/F Ratio: Controls closed throttle A/F ratio based on rpm.

EEC-IV Technical Notes: Modifications/Upgrades69

last edited: 9/29/98

Eectch98-Part5.fm

Part Throttle A/F Ratio: Controls part throttle A/F ratio based on rpm. Wide Open Throttle (WOT) A/F Ratio: Controls WOT A/F ratio based on rpm. Air Charge Temperature (ACT) Multiplier: Richens or leans the fuel based on inlet air temperature. Engine Coolant Temperature (ECT) Multiplier: Richens or leans the fuel based on engine coolant temperature. In other words, its the choke. Throttle Position (TP) Multiplier: Richens or leans the fuel based on throttle opening. Manifold Absolute Pressure (MAP) Multiplier: Richens or leans the fuel based on manifold pressure, either vacuum or boost. Transitional Fuel Enrichment (TFE): This richens the fuel when opening the throttle, like a carburetors accelerator pump. Injector Offset Adder: This corrects for injector offset; the time it takes for the injector to open. Programmable Output Fuel Multiplier: Richens or leans the fuel based on the output state of each of the four available output channels. What you hook up to these channels is up to you. Analog Input Fuel Multiplier: Richens or leans the fuel based on the input voltage of each of the three available channels. You decide what you want these channels connected to. Setting up each of these fuel control parameters means the EPEC wants to know when the enrichment (or leaning) should begin, how much enrichment you want and when to turn it off. It might ask for an either/or decision, such as, do you want this form of enrichment if these other three enrichments are already underway? It can be complex, as there are many layers to go through. There is a stock default setting saved so you can get back to a standard calibration with minimal keystrokes. Also, you can save several custom calibrations of your own to save reinventing the calibration. The spark functions are: Idle Spark Adder/Subtractor: Advances or retards spark based on rpm at idle. Part Throttle Spark Adder/Subtractor: Advances or retards spark based on rpm at part throttle. Wide Open Throttle (WOT) Spark Adder/Subtractor: Advances or retards spark based on rpm at WOT. Air Charge Temperature (ACT) Spark Adder/Subtractor: Advances or retards spark based on air inlet temperature. Engine Coolant Temperature (ECT) Spark Adder/Subtractor: Advances or retards spark based on engine temperature. Barometric Pressure (BP) Spark Adder/Subtractor: Advances or retards spark based on barometric pressure. Throttle Position (TP) Spark Adder/Subtractor: Advances or retards spark based on throttle opening Manifold Absolute Pressure (MAP) Spark Adder/Subtractor: Advances or retards spark based on manifold pressure (load). Requires fitment of a GM MAP sensor.

EEC-IV Technical Notes: Modifications/Upgrades70

last edited: 9/29/98

Eectch98-Part5.fm

Boost Retard Subtractor: Retards spark in degrees per lb. of boost based on rpm. Nitrous Spark Retard Subtractor: Retards spark during nitrous oxide operation (two stages). Programmable Output Spark Adder/Subtractor: Advances or retards spark based on the output state of each programmable output channel. You select what device these channels are connected to. Analog Input Spark Adder/Subtractor: Advances or retards spark based on the input voltage of each analog input channel. You decide what device to connect to these channels. EPEC offers a 16-channel data logger that is fully programmable, so you can choose what data to log, at what time, for how long and through which limits. The amount of memory in the EPEC is limited, of course, so the more functions logged and the longer information is logged, the fewer data points and the slower the hertz (points per second) youll get. There is plenty of memory for logging drag strip runs in useful time frames with many parameters, however. Essentially any data the EEC takes in can be logged, plus whatever you hook to the four programmable outputs and three analog inputs. By looking at things like the mass air meter and oxygen sensor signals, along with the usual rpm measurements, interesting phenomenon and correlations can be seen. Because EPEC is already monitoring rpm and has its own clock, its a cinch to let it control nitrous solenoids or other time/rpm dependent gear. Thus it makes a fullfunction nitrous controller. Theres also a spare I/O wire from EPEC which can turn on something as simple as a bulb (Make your own shift light?), or any other device. Sam believes racers will use it to turn on a second data logger rigged to chassis inputs such as driveshaft speed, suspension travel and so on. EPEC can also perform all ignition boost retard functions. This requires a MAP sensor (also useful for data logging). It recognizes the common GM MAP sensor, so the hardware is easily available. EPEC can also easily handle rev-limiting duties under its regular menu, including two-step functions. Source: Ford Motorsport SVO 44050 N. Groesbeck Highway Clinton Township, MI 48036-1108 (810) 468-1356

EEC-IV Technical Notes: Modifications/Upgrades71

last edited: 9/29/98

Eectch98-Part6.fm

Technical Notes on The EEC-IV MCU

REFERENCE
Compiled by Tom Cloud <cloud@peaches.ph.utexas.edu> (font is Courier New)

EEC APPLICATIONS
A9L is the most common 89-93 MAF 5-speed computer catch code. T4M0 is the most common 94-95 MAF 5-speed/E0D computer catch code. J4J1 is the catch code on 94-95 Cobra computers. ZA0 is the catch code used on the Cobra-R. AKC0 is used by FMS for the Lightning Mass Air conversion.

engine
5.0 5.? 5.8 5.8 2.9 1.9 1.9 2.3 2.3 2.9 2.9 5.0 5.0 2.9 3.0 5.0 5.0 460 5.0 2.3 5.8 5.0 4.0 4.6 5.8 5.8 5.0

vehicle
truck CA truck CA truck CA Bronco,F-x50 Scorpio Escort Escort Mustang Tempo Ranger Scorpio TBird Mustang Ranger Taurus Bronco Bronco F350 Bronco TBird Turbo Bronco,F-x50 F-150 Ranger/Explr Crown Vic Bronco,F-x50 Bronco,F-x50 Mustang

year efi type xmsn diff Code Calibration


95 MAF MAF MAF E4OD E4OD E4OD 4.1 3.55 4.1

Part Number
F5TF-12A650-HB F5TF-12A650-GB F5TF-12A650-BYA

MAF 88

88

SD

91

SD

93

39D1 7GYA 8AM 8BB 8CC 8DN 8DR 8GHB 8KC 8LD 8ML 8NC 8PZ 8PZ 8SE 5-spd 3.55 8TP 8UA A0C3 E4OD 3.55 A1C A1S A2J1 A2Z A2Z1 5-spd 2.73 A3M

E9AF-14A624-AA

3-21A-R10

F3ZF-12A650-DA

Table 63: PCM Applications

EEC-IV Technical Notes: Reference

72

last edited: 9/29/98

Eectch98-Part6.fm

engine
5.0 5.0 5.0 5.0 5.0 5.0 1.9 1.9 5.0 1.9 3.0 4.0 1.9 1.9 5.8 4.0 3.8 3.0 3.0 3.8 3.8 4.0 5.8 3.8 4.0 5.8 5.0 5.8 4.6 4.6 5.8 5.8 5.0 5.0 2.8 2.9 2.9 3.0 4.0 5.8 5.0 5.0 5.0 3.0 3.0 5.8

vehicle
Mustang Mustang Mustang Mustang Mustang / CA Mustang Escort Escort TBird Escort Ranger Ranger/Explr Escort Escort Lightning FMS Ranger/Explr TBird SC Taurus SHO Taurus SHO Cougar TBird Ranger/Explr Bronco,F-x50 TBird SC Ranger/Explr Bronco,F-x50 Bronco Bronco,F-x50 Crown Vic Crown Vic Lightning Lightning Mustang Mustang Ranger Ranger Ranger Cougar Ranger/Explr Bronco,F-x50 TBird Mustang Mustang Taurus Taurus Bronco,F-x50

year efi type xmsn diff Code Calibration


MAF 89-93 MAF MAF MAF MAF 89 MAF 5-spd 2.73 A3M1 5-spd A9L A9M A9P 5-spd A9S A9T AA2 AB2 AB2 AB3 ACE1 ADZ1 AF1 AH1 E4OD AKC0 ANY1 B9A1 B9B B9B1 B9L1 B9L2 BAT1 BTQ C0S C1J C1Z C2M1 C2M1 C2Z3 C3N3 E4OD C3P1 E4OD C3P2 auto C3W auto C3W1 C9B C9E1 C9M CE COW1 D1X D2L 3.08 D3D 3.08 D3D1 D9C D9C1 D9D1

Part Number
E9ZF-12A650-AA

n/a

MAF

F8TF-12A650-NA

93 93

MAF

F3ZF-12A650-FA F3ZF-12A650-FB

F3ZF-12A650-EA F3ZF-12A650-EB

Table 63: PCM Applications

EEC-IV Technical Notes: Reference

73

last edited: 9/29/98

Eectch98-Part6.fm

engine
5.8 5.0 460 5.0 5.0 5.0 4.6 5.0 5.8 4.0 4.0 5.0 4.6 1.9 2.3 2.3 5.8 5.0 5.8 5.0 5.0 3.2 4.0 2.9 460 3.0 5.0 5.8 4.0 5.0 4.0 3.0 5.0 1.9 4.6 2.3 2.3 2.3 2.3 2.3 2.9 3.8 4.6

vehicle
Bronco,F-x50 MK7 Mustang Van Mustang Mustang TBird Crown Vic Mustang Bronco,F-x50 Ranger/Explr Ranger/Explr TBird Crown Vic Escort Mustang Mustang SVO Bronco,F-x50 Mustang Bronco,F-x50 TBird TBird Taurus SHO Ranger/Explr Ranger F350 Ranger Cobra Bronco Ranger/Explr TBird Probe V6 Ranger/Explr Taurus SHO Bronco Escort Crown Vic TBird Turbo TBird Turbo TBird Turbo TBird Turbo TBird Turbo Ranger TBird SC MK7 Crown Vic

year efi type xmsn diff Code Calibration


D9L1 D9S DA1 DAD DC DE DG1 DH DX3 E0D E0E E0L E1X E3Y2 F1X FB2 FB2 FK1 GJ1 GT H2M H2M1 H3Z HAG0 5-spd HD J2C1 J2Z J4J1 E4OD 3.55 JOG1 K1P0 KF KLO7 L0D L0S L12D L1X L2W LA LA2 LA3 LB2 LB3 LDP1 LOE1 M1L1 M2C

Part Number

87

SD/SFI

E7SF-12A650-A1B

87

SD

94-95 95 SD

Table 63: PCM Applications

EEC-IV Technical Notes: Reference

74

last edited: 9/29/98

Eectch98-Part6.fm

engine
3.0 3.8 1.9 5.0 5.0 3.0 3.8 4.0 4.0 4.0 5.0 4.0 2.3 2.3 2.3 2.3 2.3 2.3 2.3 4.0 2.9 2.9 3.8 2.0 5.0 5.0 2.3 2.3 2.3 2.3 5.8 3.8 5.0 1.9 4.0 4.0 4.0 5.0 2.3 5.0 5.0 5.0 1.9 3.8

vehicle
Ranger TBird SC Escort TBird G.Marquis Ranger TBird Ranger/Explr Ranger/Explr Ranger/Explr TBird Ranger/Explr Mustang SVO Mustang SVO Merkur Turbo Merkur Turbo Mustang SVO Mustang SVO Mustang SVO Ranger/Explr Ranger Bronco II LTD Probe 16V Econoline Mustang TBird Turbo Mustang SVO TBird Turbo TBird Turbo Bronco,F-x50 TBird SC Mustang Explorer Escort Ranger/Explr Ranger/Explr Ranger/Explr Mustang Mustang SVO Mustang Mustang Mustang diesel pickup Escort TBird SC

year efi type xmsn diff Code Calibration


M2T M2Y M2Z MC2 MN MOM2 MP NAP2 OLD2 P0X0 P3M PAN1 PC1 PE PF2 PF3 PJ PK PK1 RAT1 RM2 RP SX T T2T T4MO TA TE TE TF U2U1 U2Y U4PO UB UB UMP1 VAN VET1 VH2 VJ1 VJ1 VM1 VR1 W1D W1E W1M

Part Number

86

SD

A4LD

94-95 MAF

EOD

86 86

E6EF-12A650-B1A

86

SFI

E6SF-12A650-H1C

89

F1TF-12B565-CA

Table 63: PCM Applications

EEC-IV Technical Notes: Reference

75

last edited: 9/29/98

Eectch98-Part6.fm

engine
5.0 5.8 460 3.0 3.8 4.0 5.8 3.8 3.8 3.0 4.0 5.0 4.0 3.8 4.0 5.8 3.8 5.8 2.3 2.3 2.3

vehicle
Bronco Bronco,F-x50 F350 Taurus SHO MK8 TBird SC Ranger/Explr Bronco,F-x50 TBird TBird SC Taurus SHO XR7 Ranger/Explr Cobra Ranger/Explr TBird SC Ranger/Explr Bronco,F-x50 TBird MK8 Cobra-R TBird Turbo Mustang SVO TBird Turbo

year efi type xmsn diff Code Calibration


W2J W2J W2T W2Z W3Z2 W4D2 X0A X0P X1A2 X1A2 X2J X2P X2T2 X3Z YAM1 Z1Z2 Z2C2 Z2D1 Z2U2 Z4H0 ZA0 ZAA ZBA ZGA Table 63: PCM Applications

Part Number

93

FEZF-12A650-CA

TERMS
Abbrev.
A/C ACCS ACC ACT ACV AOD AXOD BOO BP CANP CCO CDR CFI CID CKT DIS

Meaning
Air Conditioning A/C Cycling Switch A/C Clutch Compressor Air Charge Temperature sensor Thermactor Air Control Valve Automatic Overdrive Transmission Automatic Transaxle Overdrive Brake On/Off switch Barometric Pressure sensor Canister Purge solenoid Converter Clutch Override Crankcase Depression Regulator Central Fuel Injection Cylinder Identification sensor Circuit Direct Ignition System (see also EDIS, TFI) Table 64: EEC Related Terms

EEC-IV Technical Notes: Reference

76

last edited: 9/29/98

Eectch98-Part6.fm

Abbrev.

Meaning

DVOM Digital Volt/Ohm Meter E4OD Electronic 4-speed OverDrive Transmission ECA Electronic Control Assembly (processor, computer) (see MCU) ECM Electronic Control Module (see MCU) ECT Engine Coolant Temperature ECU Electronic Control Unit (see MCU) EDF Electric Drive Fan relay assembly EDIS Electronic DIStributor (see also DIS, TFI) EEC Electronic Engine Control EGO Exhaust Gas Oxygen sensor (see HEGO) EGR Exhaust Gas Recirculation system EGRC EGR Control solenoid or system EGRV EGR Vent solenoid or system EVP EGR Position sensor EVR EGR Valve Regulator FI Fuel Injector or Fuel Injection FDM Fuel Delivery Module FP Fuel Pump FPM Fuel Pump Monitor GND or GRND Ground (see also PWR GND) HEDF High Speed Electro Drive Fan relay or circuit HEGO Heated EGO sensor HEGOG HEGO Ground circuit HO High Output HSC High Swirl Combustion, engine type IDM Ignition Diagnostic Module IGN Ignition system or circuit INJ Injector or Injection ISC Idle Speed Control ITS Idle Tracking Switch KAM Keep Alive Memory KAPWR Keep Alive Power KOEO Key On Engine Off KOER Key On Engine Running KS Knock Sensor L Liter(s) LOS Limited Operation Strategy (computer function) LUS Lock-Up Solenoid MAF Mass Air Flow sensor, meter or circuit MA PFI Mass Air Sequential Port Fuel Injection system MCU Microprocessor Control Unit MIL Malfunction Indicator Light MPFI Multi Port Fuel Injection NDS Neutral Drive Switch NGS Neutral Gear Switch NPS Neutral Pressure Switch Table 64: EEC Related Terms

EEC-IV Technical Notes: Reference

77

last edited: 9/29/98

Eectch98-Part6.fm

Abbrev.
OCC OHC OSC PCM PFE PFI PIP PSPS PWR GND RWD SC SIG RTN SIL SPOUT SS STAR STI STO TAB/TAD TAPS TFI TGS THS TP/TPS TTS VAF VAT VBATT VM VOM VPWR VREF VSC VSS WAC WOT

Meaning
Output Circuit Check Over Head Camshaft (engine type) Output State Check Powertrain Control Module Pressure Feedback EGR sensor or circuit Port Fuel Injection Profile Ignition Pickup Power Steering Pressure Switch Power Ground circuit (see also GND) Rear Wheel Drive Super Charged (engine type) Signal Return circuit Shift Indicator Light Spark Output Signal from ECA Shift Solenoid circuit Self Test Automatic Readout (test equipment) Self Test Input circuit Self Test Output circuit Thermactor Air Bypass/Diverter Tandem solenoid valves Throttle Angle Position Sensor (see TP/TPS) Thick Film Ignition system (see DIS, EDIS) Top Gear Switch (cancels SIL operation in top gear) Transmission Hydraulic Switch Throttle Position Sensor Transmission Temperature Switch Vane Air Flow sensor or circuit Vane Air Temperature Vehicle Battery Voltage Vane Meter Analog Volt/Ohm Meter Vehicle Power supply voltage (regulated 10-14 volts) Voltage Reference (ECA supplied reference voltage 4-6 volts) Vehicle Speed Control sensor or signal Vehicle Speed Sensor or signal WOT A/C Cut-off switch or circuit Wide Open Throttle Table 64: EEC Related Terms

EEC-IV REFERENCE SOURCES:


The Engine/Emissions Diagnosis manual, available for specific models and years, covers all emissions related maintenance procedures. It is available from Helm, Inc., (800) 782-4356. "How to Understand, Service, and Modify Ford Fuel Injection and Electronic Engine Control", by Charles O. Probst, published by Robert Bentley of Cambridge, MA, USA, ISBN 0-8376-0301-3. It is available from a Ford Motorsports dealers and Classic Motorbooks at (800) 826-6600. It gives an overview of the sensors, actuators, and control algorithms used by the EEC-IV, step-by-step diagnostic procedures, wiring

EEC-IV Technical Notes: Reference

78

last edited: 9/29/98

Eectch98-Part6.fm

diagrams and tips on hot-rodding EEC-IV cars. SAE paper #820900, "EEC-IV Tomorrows Electronic Engine Controls Today", David Hagen & Dennis Wilkie, Ford Motor Co., Dearborn, MI Intel 8096 (MCS-96) literature. One document, available from their web site, is "27006102.pdf" entitled "APPLICATION NOTE; AP-248; Using The 8096"; Order Number: 270061-002. There are many other related documents available from Intel -- including the use of the A-D converter, the implementation of "fuzzy logic", instrumenting and controlling automotive applications, and other topics.

AFTER-MARKET SUPPLIERS:
Connectors for the EEC are apparently proprietary also, though some have said they are available through Amp, Farnell and DigiKey. There seem to be two channels of ECM availability: 1 - OEMs and the companies they authorize, who together provide remanufactured ECMs through dealer channels; 2 - and those involved in the remanufacturing of ECMs for the true automotive aftermarket. - A1 Cardone - Echlin - Micro-Tech Automotive - Standard Motor Parts Some of these companies catalog and offer product (or repair service) on almost 800 different ECM configurations for Ford-made vehicles in the model years from 19771993. Some of these are consolidations of applications, where units have proven and tested to be comparable. Foreign made vehicles sold under the Ford nameplate would add to this population of ECMs, since the above count is only Ford units. For an idea of what the EEC does, and what can be done with it, get a demo of Mike Wesleys calibrator for the EEC-IV at: http://www.tiac.net/users/goape/index.htm

EEC-IV Technical Notes: Reference

79

last edited: 9/29/98

You might also like