aboutsummaryrefslogtreecommitdiff
path: root/src/drivers/siemens/nc_fpga/nc_fpga.c
diff options
context:
space:
mode:
authorMario Scheithauer <mario.scheithauer@siemens.com>2017-06-12 10:02:10 +0200
committerWerner Zeh <werner.zeh@siemens.com>2017-06-13 10:27:19 +0200
commitc4ff1de8bf65718a7fcb1aa3a77f7024140fecef (patch)
tree3b7ca4ba72860b01a3f3a908abeb86209a1d68a8 /src/drivers/siemens/nc_fpga/nc_fpga.c
parent59dd4664148ffcff5af4b23b320bf9bb99c28a63 (diff)
siemens/nc_fpga: Expand FPGA functionality
The siemens/mc_apl1 mainboard needs more functionality provided by Siemens NC FPGA. The additional functionality contains backlight brightness/PWM control and Dsave time for board reset. Change-Id: I6b65b01f0d67afe598b7c005868f71b00dec56fd Signed-off-by: Mario Scheithauer <mario.scheithauer@siemens.com> Reviewed-on: https://review.coreboot.org/20160 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Werner Zeh <werner.zeh@siemens.com> Reviewed-by: Paul Menzel <paulepanter@users.sourceforge.net>
Diffstat (limited to 'src/drivers/siemens/nc_fpga/nc_fpga.c')
-rw-r--r--src/drivers/siemens/nc_fpga/nc_fpga.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/drivers/siemens/nc_fpga/nc_fpga.c b/src/drivers/siemens/nc_fpga/nc_fpga.c
index def456bbb6..59e7d4bd2f 100644
--- a/src/drivers/siemens/nc_fpga/nc_fpga.c
+++ b/src/drivers/siemens/nc_fpga/nc_fpga.c
@@ -119,6 +119,17 @@ static void nc_fpga_init(struct device *dev)
init_temp_mon(bar0_ptr + NC_FANMON_CTRL_OFFSET);
if (cap & NC_CAP1_FAN_CTRL)
init_fan_ctrl(bar0_ptr + NC_FANMON_CTRL_OFFSET);
+ if (cap & NC_CAP1_DSAVE_NMI_DELAY) {
+ uint16_t *dsave_ptr = (uint16_t *)(bar0_ptr + NC_DSAVE_OFFSET);
+ FPGA_SET_PARAM(NvramVirtTimeDsaveReset, *dsave_ptr);
+ }
+ if (cap & NC_CAP1_BL_BRIGHTNESS_CTRL) {
+ uint8_t *bl_bn_ptr =
+ (uint8_t *)(bar0_ptr + NC_BL_BRIGHTNESS_OFFSET);
+ uint8_t *bl_pwm_ptr = (uint8_t *)(bar0_ptr + NC_BL_PWM_OFFSET);
+ FPGA_SET_PARAM(BL_Brightness, *bl_bn_ptr);
+ FPGA_SET_PARAM(PF_PwmFreq, *bl_pwm_ptr);
+ }
}
static struct device_operations nc_fpga_ops = {
@@ -130,10 +141,10 @@ static struct device_operations nc_fpga_ops = {
.ops_pci = 0,
};
-static const unsigned short nc_fpga_device_ids[] = { 0x4091, 0 };
+static const unsigned short nc_fpga_device_ids[] = { 0x4080, 0x4091, 0 };
static const struct pci_driver nc_fpga_driver __pci_driver = {
.ops = &nc_fpga_ops,
- .vendor = 0x110A,
+ .vendor = PCI_VENDOR_ID_SIEMENS,
.devices = nc_fpga_device_ids,
};