google/pyro: set i2c bus timings by rise/fall times

Provide the rise and fall times for the i2c buses and let the
library perform the necessary calculations for the i2c
controller registers instead of manually tuning the values.

BUG=chrome-os-partner:58112
BRANCH=master
TEST=emerge-pyro coreboot
Change-Id: I68be9b96dc731eb0084ee5e15921866818637e73
Signed-off-by: Kevin Chiu <Kevin.Chiu@quantatw.com>
Reviewed-on: https://review.coreboot.org/17652
Tested-by: build bot (Jenkins)
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
Kevin Chiu 2016-11-30 16:30:28 +08:00 committed by Aaron Durbin
parent 152c0ee5d0
commit 35d7d586cd

View file

@ -71,50 +71,33 @@ chip soc/intel/apollolake
register "gpe0_dw2" = "PMC_GPE_N_63_32" register "gpe0_dw2" = "PMC_GPE_N_63_32"
register "gpe0_dw3" = "PMC_GPE_SW_31_0" register "gpe0_dw3" = "PMC_GPE_SW_31_0"
# Limit I2C0 Audio codec da7219 speed to 400kHz with manually tuned values. # Enable I2C0 for audio codec at 400kHz
register "i2c[0]" = "{ register "i2c[0]" = "{
.speed = I2C_SPEED_FAST, .speed = I2C_SPEED_FAST,
.speed_config[0] = { .rise_time_ns = 104,
.speed = I2C_SPEED_FAST, .fall_time_ns = 52,
.scl_lcnt = 0xd0,
.scl_hcnt = 0x68,
.sda_hold = 0x27,
}
}" }"
# Enable I2C2 bus early for TPM access and configure as 400kHz # Enable I2C2 bus early for TPM at 400kHz
# with manually tuned values.
register "i2c[2]" = "{ register "i2c[2]" = "{
.early_init = 1, .early_init = 1,
.speed = I2C_SPEED_FAST, .speed = I2C_SPEED_FAST,
.speed_config[0] = { .rise_time_ns = 50,
.speed = I2C_SPEED_FAST, .fall_time_ns = 23,
.scl_lcnt = 0xd0,
.scl_hcnt = 0x68,
.sda_hold = 0x27,
}
}" }"
# Limit I2C3 WACOM touchscreen speed to 400kHz with manually tuned values. # touchscreen at 400kHz
register "i2c[3]" = "{ register "i2c[3]" = "{
.speed = I2C_SPEED_FAST, .speed = I2C_SPEED_FAST,
.speed_config[0] = { .rise_time_ns = 76,
.speed = I2C_SPEED_FAST, .fall_time_ns = 164,
.scl_lcnt = 0xd0,
.scl_hcnt = 0x68,
.sda_hold = 0x27,
}
}" }"
# Limit trackpad speed to 400kHz with manually tuned values. # trackpad at 400kHz
register "i2c[4]" = "{ register "i2c[4]" = "{
.speed = I2C_SPEED_FAST, .speed = I2C_SPEED_FAST,
.speed_config[0] = { .rise_time_ns = 90,
.speed = I2C_SPEED_FAST, .fall_time_ns = 164,
.scl_lcnt = 0xd0,
.scl_hcnt = 0x68,
.sda_hold = 0x27,
}
}" }"
# Minimum SLP S3 assertion width 28ms. # Minimum SLP S3 assertion width 28ms.