Professional Documents
Culture Documents
Robert Rauscher
10/14/2000, updated 12/4/00
This is specific to the 747 ecm. However, the methods and madness applies to many of the
GM ecm's. (Use at your own risk, no guarantee that any of this is correct.)
Note:
INTRO:
The IAC position and control are measured in steps. One step moves the pintle a small
amount. The full range is typically from zero steps to two-hundred steps. Zero steps are
when the pintle is fully extended, closing off all IAC bleed air flow.
As the steps are increased, the pintle is retracted from the orifice,
allowing more air to bypass the throttle blades. This has the effect
of increasing the engine speed. Remember that an IAC retract (or an increase in steps),
opens the air passage to raise the engine speed.
BASIC OPERATION:
With the engine off, the IAC will be at the park position. This is
the position used upon cranking the engine. Once the engine starts, the ecm will start to
move the IAC to another position. This position is from a table lookup of steps vs.
coolant and a baro correction.
However, the IAC does not move to the new position immediately. If it did, the engine
would react suddenly, possibly stalling. The difference between the original park steps,
and the newly desired steps vs. coolant, are lag filtered. These filters control the rate
at which the IAC moves.
Once the IAC has moved to it's new position, the idle logic starts to act. The goal here
is to attain, then maintain, the desired idle rpm. Is does not matter whether the engine
is in closed loop or open loop, the idle logic takes over.
A key here is: As long as the current idle speed touches the desired idle rpm plus the
idle error term, within the time delay, no change to the idle speed will take place. If
the idle goes outside of the limits, the IAC will be moved to compensate.
Now that the engine is idling, sooner or later the driver will hit the
gas. Now the throttle follower logic kicks in. As the tps% increase, so does the IAC
steps. Again, this action is lag filtered. As the throttle is then closed, the IAC
retracts, lag filtered.
Upon the engine being shut off, the IAC goes through a reset process. The IAC is stepped
to the reset position, stepped to the zero position, then stepped to the park position.
This calibrates the positioning of the IAC, along with leaving it in place for the next
cranking to start.
There are additional factors that affect the IAC position. If the battery voltage dips,
the IAC can increase the idle. The A/C turning on, or decel fuel cutoff (DFCO), can
affect the current IAC position.
For an idea of how these factors can work, I'll use the A/C turning
on as an example. With the engine at IAC controlled idle, and the A/C turning on,
additional steps are immediately added to the current IAC position. Another table value
also adds to the desired idle rpm. Lets say the desired idle rpm went from 800 rpm, to
850 rpm.
The steps that were added, are decayed out. However, the idle logic is also attempting to
hold the idle at the newly desired rpm. An astute driving may notice a slight increase in
idle, along with a dip in idle, as the new idle speed is attained by the ecm.
0x293: Additional fuel added during IAC opening. (val = msec * 16.384).
Acts like a pump shot (Do not use as one.)
0x5C1:
0x5C2: IAC park position. IAC is immediately moved to this position after engine stop and
IAC reset completion. This is the IAC position for engine cranking and start.
0x5C3: Park to run delay. Delay from engine start, to the IAC moving to the run position:
IAC vs. coolant. (val = seconds * 40)
0x5C4: Stall saver cut-in rpm (rpm / 12.5). If the engine rpm drops
below this value, the IAC is further retracted according to the steps in the stall saver
table at: 0x60A, four lines, lookup by baro. This action is immediate and not subject to
lag filtering.
0x5C5: Stall saver cut-out rpm (rpm / 12.5). Once above this rpm,
the above added steps are decayed out (lag filtered).
0x5C6: %tps for idle threshold. Used in conjunction with a hardcoded 0 mph. These two
values define whether the engine is in idle or not. If engien is not considered to be in
idle, no idle speed control is attempted.
0x5C7: Time delay for small error IAC retract. (desired idle too low)
0x5C8: Time delay for large error IAC retract. (desired idle too low)
0x5C9: Time delay for small error IAC extend. (desired idle too high)
0x5CA: Time delay for large error IAC extend. (desired idle too high)
The past four entries are used to slow-down, or delay, the operation of the IAC at idle.
When in closed loop idle, the IAC attempts to maintain the desired idle. The error term
is the difference between the desired idle rpm and the current engine rpm.
A larger error term has a shorter delay, to move the IAC quicker. Once the idle is close,
the delay is longer. This is done for better control of the idle speed.
If the engine idle oscillates wildly, seems like the IAC can not
'keep-up', increasing these values (slightly), may correct it. Note
that an oscillating idle can also be caused by incorrect VE% and SA tables.
These past two entries are the rpm breakpoints for the previous four IAC error time
delays.
0x5CD: Idle deadband (rpm/12.5). Amount of idle variance allowed within the time delay
(0x5C7 - 0x5CA). More than this amount will cause the IAC to respond, affecting the
current idle speed.
0x5CE: IAC reset steps. Upon engine stop, the IAC is retracted
to this position, moved to zero steps, then parked at park steps (0x5C2).
0x5D3 & 0x5D4: DFCO steps. Number of steps to add to IAC whenever DFCO is in effect. Will
not be decayed out until DFCO is no longer in effect. This status is from the fuel
routines. Uses decay filter coeficient @ 0x5EA.
Note that this is a double byte value. The actual steps are in 0x5D3, with a fractional
amount in 0x5D4. So set 0x5D4 to 0.
0x5D6: Added steps for A/C on. These steps are immediately added upon the A/C being
switched on. They are decayed out, with the idle control logic maintaining the desired
idle.
These two together form a post-startup rpm reduction. The kickdown delay timer starts
right after startup. Once the timer has expired, the IAC is extended by the amount of
kickdown steps.
A nuance: The kickdown steps must be less than the steps used in the IAC position vs.
coolant table value (0x5F5): Otherwise kickup will occur. The kickdown steps are
subtracted from the IAC position steps, and are added to a term that is decayed out.
0x5D9: IAC steps subtracted from current idle position when placed into gear (auto).
0x5DA: Additional idle speed, added to desired idle rpm when A/C on. (rpm / 12.5).
0x5DB: Idle rpm for closed loop aldl diag mode (rpm / 12.5). Used
for troubleshooting.
Whenever the vehicle voltage drops by the value in 0x5DD, the IAC is retracted by the
steps listed in 0x5DC. This is intended to
bump up the idle to maintain alternator output.
As long as the vehicle voltage drop IAC bump is in effect, the IAC
steps will not be decayed out.
0x5DE: Maximum IAC steps. This is the maximum retract steps allowed.
(Except for engine stop reset).
There is one of three filter coefficients used depending upon the vehicle speed. A higher
value has less filter action, increasing the IAC speed.
Delays IAC extend after an IAC retract command. Can cause a 'rpm hang' after a throttle
blip or throttle lift.
These filters are used to decay out IAC step increases due to items such as the battery
volt drop, DCFO, hot restart retracts, and kickdown.
These are the VSS thresholds used to define which filter coefficient to use. Selected
from the values at 0x5E4 - 0x5E6, depending upon VSS.
0x5EE: Minimum IAC throttle follower steps when above Low VSS. Whenever the vehicle speed
is above the mph defined at 0x5EC, the IAC TF will not step lower than this value.
---------------------------------------------------------------------------------
The throttle follower value along with the filter coefficients affect how the engine
returns to idle after the throttle is closed. This includes both a return to idle on a
throttle blip, along with affecting ease of shifting (manual tranny). Note that the
throttle follower IAC retract steps are not filtered. The IAC opens as quickly as the
throttle in opened.
0x5F3: A coolant temperature value for a cold kick down enable? Used to enable the use of
the values @ 0x5E1, 0x5E2 & 0x5E3.
0x5F4: N-bias. The first time this speed is exceeded, the current IAC
count in L00CC is added to L00CB. I am not sure of the intention of this.
I have found that it is better to set the IAC position vs. coolant
values a little on the low side. This allows the rpm to drop below the desired idle
speed, to then be 'caught'. Otherwise, it seems as though the idle never drops down to
where it should be.
0x606: IAC position vs baro at reset (in steps). 4 line table, added
to the IAC position vs. coolant lookup. Do not set this table too low, it appears to have
something to do with how much idle adjustment can be made.
0x60A: Stall saver IAC increase vs baro (in steps). 4 line table.
Whenever the idle drops below the stall-saver speed (0x5C4), the IAC is immediately
retracted by this table value. Once the rpm rises above the stall-saver cutout speed
(0x5C5), the added steps are decayed out.
The stall saver decay filter coeficient is at: 0x5EB.
0x60E: Desired idle rpm versus the coolant temperature. Nine line table, from 55c to 135c
inclusive, in 10c intervals. Value is rpm / 12.5.
This is the end goal, the rpm at which the engine should idle. I have found that the
table range is a bit on the high temperature side. When running cold aluminum manifolds,
there may be little difference in the desired idle speed between 55c and 65c coolant.
MECHANICAL EFFECTS:
(I want to thank Bruce Plecan for discovering and documenting this gem).
With a TBI system, the IAC steps at idle can be crucial. Again, I am
referring to the hot'r street type engines. A rumpity-rump engine needs all the help it
can get to idle. One area to be addressed is that of the throttle blade setting.
A typical TBI system will idle with an IAC count of 35 to 45. On a cam'd engine, zero
steps may be better. Myself, I shoot for three to five steps with a warm engine, and no
A/C. The reason for this has to do with the injectors residing above the throttle plates.
During idle, the TBI injectors are designed to spray onto the bore walls.
When this happens, the fuel runs down the walls, and past the throttle blades. The air
speed past the throttle blades is very high. This action shears the fuel into vapor that
is then able to travel to the chambers.
If the engine idles with a high IAC count, this IAC air is bypassing
the throttle blades, hindering the flow of fuel into the plenum. By
opening the throttle blades and reducing the IAC counts, there is a greater volume of air
drawing fuel past the throttle blades.
Next time you are timing the engine, shine that light into the TBI
bores, and look. Then, knock out that throttle blade adjustment plug, and turn it in.
Just keep an eye on the IAC count, you do not want to try to get it below zero. This is
the reason I set the idle to have at least a couple of counts.
TIPS:
When turning in the TBI idle screw with the engine running:
Once the throttle opens past the TPS% value at: 0x5C6, the
IAC will stop controlling the idle speed. An engine stop,
wait ten seconds, and an engine restart will reset this value.
When idle speed has been raised (cam'd engines), also raise the
stall saver speeds.
------------------------------------------------------------------------
Random Notes:
0x303: Hot bias steps. If kickdown has not yet occurred, this
value is added to whatever is in L00C2.
Note: L00C2 will not be decayed out if any stall saver is active.
Or, throttle follower steps are active?, (in L00C6).
After startup, idle control starts with L00CE being adjusted for proper
idle speed. L00CC gets incr's as L00CE decr's, and vica-versa.
**Once N-bias mph has been reached, the value in L00CC is added to L00CB.
L00CC is then set to zero. This can cause the engine speed to increase.
The idle control logic will not lower the engine speed whenever:
This means that the vehicle must be absolutely still for the idle control
logic to reduce engine speed. Else, the steps are held where they are. Of
course, the throttle follower and stall saver are still in effect.
If the vehicle is moving, and the engine speed drops below the desired
idle, L00CD will be increased to increase engine speed. Note that this
does not cause a change in L00CC.
If L00CD == 0 and L00C6 (throttle follower), > 0, then the idle control
will not be in effect. (See F2F9). Unless stall saver is decaying out.
----------------------------------------------------------------------
-eof-