Author: stepan Date: 2007-10-30 03:03:43 +0100 (Tue, 30 Oct 2007) New Revision: 508
Added: LinuxBIOSv3/superio/fintek/ LinuxBIOSv3/superio/fintek/f71805f/ LinuxBIOSv3/superio/fintek/f71805f/Makefile LinuxBIOSv3/superio/fintek/f71805f/dts LinuxBIOSv3/superio/fintek/f71805f/f71805f.h LinuxBIOSv3/superio/fintek/f71805f/stage1.c LinuxBIOSv3/superio/fintek/f71805f/superio.c Modified: LinuxBIOSv3/Kconfig Log: I know there is still an ongoing discussion on the list about this patch, and how support for superios might look in the future. This code (like all the rest, too) will certainly change and evolve in the future, as v3 evolves.
-----
Add support for the Fintek F71805f to LinuxBIOSv3. It hasn't been tested yet because something's failing to build elsewhere, but the stage1 does build, and for the moment that's what matters. It's based on working v2 code so it should work fine.
Signed-off-by: Corey Osgood corey.osgood@gmail.com Acked-by: Stefan Reinauer stepan@coresystems.de
Modified: LinuxBIOSv3/Kconfig =================================================================== --- LinuxBIOSv3/Kconfig 2007-10-16 19:29:34 UTC (rev 507) +++ LinuxBIOSv3/Kconfig 2007-10-30 02:03:43 UTC (rev 508) @@ -84,6 +84,8 @@ # Super I/Os: config SUPERIO_WINBOND_W83627HF boolean +config SUPERIO_FINTEK_F71805F + boolean
# Source all northbridge/southbridge/superio Kconfig files: source northbridge/intel/i440bxemulation/Kconfig
Added: LinuxBIOSv3/superio/fintek/f71805f/Makefile =================================================================== --- LinuxBIOSv3/superio/fintek/f71805f/Makefile (rev 0) +++ LinuxBIOSv3/superio/fintek/f71805f/Makefile 2007-10-30 02:03:43 UTC (rev 508) @@ -0,0 +1,29 @@ +## +## This file is part of the LinuxBIOS project. +## +## Copyright (C) 2007 Corey Osgood corey.osgood@gmail.com +## +## This program is free software; you can redistribute it and/or modify +## it under the terms of the GNU General Public License as published by +## the Free Software Foundation; either version 2 of the License, or +## (at your option) any later version. +## +## This program is distributed in the hope that it will be useful, +## but WITHOUT ANY WARRANTY; without even the implied warranty of +## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +## GNU General Public License for more details. +## +## You should have received a copy of the GNU General Public License +## along with this program; if not, write to the Free Software +## Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +## + +ifeq ($(CONFIG_SUPERIO_FINTEK_F71805F),y) + +STAGE0_CHIPSET_OBJ += $(obj)/superio/fintek/f71805f/stage1.o +STAGE0_CHIPSET_OBJ += $(obj)/device/pnp_raw.o + +# Always add to variables, as there could be more than one Super I/O. +STAGE2_CHIPSET_OBJ += $(obj)/superio/fintek/f71805f/superio.o + +endif
Added: LinuxBIOSv3/superio/fintek/f71805f/dts =================================================================== --- LinuxBIOSv3/superio/fintek/f71805f/dts (rev 0) +++ LinuxBIOSv3/superio/fintek/f71805f/dts 2007-10-30 02:03:43 UTC (rev 508) @@ -0,0 +1,53 @@ +/* + * This file is part of the LinuxBIOS project. + * + * Copyright (C) 2007 Corey Osgood corey.osgood@gmail.com + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + +{ + /* Floppy */ + floppydev = "0x0"; + floppyenable = "0"; + floppyio = "0x3f0"; + floppyirq = "6"; + floppydrq = "2"; + + /* Parallel port */ + ppdev = "1"; + ppenable = "1"; + ppio = "0x378"; + ppirq = "7"; + + /* Note: renaming from comx to spx may have broken the DTS + * We'll find out later */ + /* Serial Port 1 */ + sp1dev = "2"; + sp1enable = "1"; + sp1io = "0x3f8"; + sp1irq = "4"; + + /* Serial Port 2 */ + sp2dev = "3"; + sp2enable = "1"; + sp2io = "0x2f8"; + sp2irq = "3"; + + /* Hardware Monitor */ + hwmdev = "0xb"; + hwmenable = "0"; + hwmio = "0xec00"; +};
Added: LinuxBIOSv3/superio/fintek/f71805f/f71805f.h =================================================================== --- LinuxBIOSv3/superio/fintek/f71805f/f71805f.h (rev 0) +++ LinuxBIOSv3/superio/fintek/f71805f/f71805f.h 2007-10-30 02:03:43 UTC (rev 508) @@ -0,0 +1,36 @@ +/* + * This file is part of the LinuxBIOS project. + * + * Copyright (C) 2007 Corey Osgood corey@slightlyhackish.com + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + +/* + * Datasheet: + * - Name: F71805F/FG Super H/W Monitor + LPC IO + * - URL: http://www.fintek.com.tw/eng/products.asp?BID=1&SID=17 + * - PDF: http://www.fintek.com.tw/files/productfiles/F71805F_V025.pdf + * - Revision: V0.25P + */ + +/* Logical Device Numbers (LDN). */ +#define F71805F_FDC 0x00 /* Floppy */ +#define F71805F_SP1 0x01 /* UART1 */ +#define F71805F_SP2 0x02 /* UART2 */ +#define F71805F_PP 0x03 /* Parallel Port */ +#define F71805F_HWM 0x04 /* Hardware Monitor */ +#define F71805F_GPIO 0x06 /* General Purpose I/O (GPIO) */ +#define F71805F_PME 0x0a /* Power Management Events (PME) */
Added: LinuxBIOSv3/superio/fintek/f71805f/stage1.c =================================================================== --- LinuxBIOSv3/superio/fintek/f71805f/stage1.c (rev 0) +++ LinuxBIOSv3/superio/fintek/f71805f/stage1.c 2007-10-30 02:03:43 UTC (rev 508) @@ -0,0 +1,41 @@ +/* + * This file is part of the LinuxBIOS project. + * + * Copyright 2007 Corey Osgood corey.osgood@gmail.com + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#include <io.h> +#include <device/pnp.h> +#include "f71805f.h" + +static inline void f71805f_rawpnp_enter_ext_func_mode(u8 dev) +{ + /* Fintek F71805f needs this only once, but Winbond needs it twice. + * Perhaps modify rawpnp_enter_ext_func_mode() to only do it once, + * then modify the winbond to call it twice? */ + outb(0x87, dev); +} + +void f71805f_enable_serial(u8 dev, u8 serial, u16 iobase) +{ + f71805f_rawpnp_enter_ext_func_mode(dev); + rawpnp_set_logical_device(dev, serial); + rawpnp_set_enable(dev, 0); + rawpnp_set_iobase(dev, PNP_IDX_IO0, iobase); + rawpnp_set_enable(dev, 1); + rawpnp_exit_ext_func_mode(dev); +}
Added: LinuxBIOSv3/superio/fintek/f71805f/superio.c =================================================================== --- LinuxBIOSv3/superio/fintek/f71805f/superio.c (rev 0) +++ LinuxBIOSv3/superio/fintek/f71805f/superio.c 2007-10-30 02:03:43 UTC (rev 508) @@ -0,0 +1,117 @@ +/* + * This file is part of the LinuxBIOS project. + * + * Copyright 2007 Corey Osgood corey.osgood@gmail.com + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; version 2 of the License. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + +/* Ported from v2 driver */ + +#include <io.h> +#include <lib.h> +#include <device/device.h> +#include <device/pnp.h> +#include <console.h> +#include <string.h> +#include <uart8250.h> +#include <statictree.h> +#include "f71805f.h" + +static void enable_dev(struct device *dev); +void f71805f_pnp_set_resources(struct device *dev); +void f71805f_pnp_set_resources(struct device *dev); +void f71805f_pnp_enable_resources(struct device *dev); +void f71805f_pnp_enable(struct device *dev); +static void f71805f_init(struct device *dev); + +static void pnp_enter_conf_state(struct device *dev); +static void pnp_exit_conf_state(struct device *dev); + +static void pnp_enter_conf_state(struct device *dev) +{ + outb(0x87, dev->path.u.pnp.port); +} + +static void pnp_exit_conf_state(struct device *dev) +{ + outb(0xaa, dev->path.u.pnp.port); +} + +void f71805f_pnp_set_resources(struct device *dev) +{ + pnp_enter_conf_state(dev); + pnp_set_resources(dev); + pnp_exit_conf_state(dev); +} + +void f71805f_pnp_enable_resources(struct device *dev) +{ + pnp_enter_conf_state(dev); + pnp_enable_resources(dev); + pnp_exit_conf_state(dev); +} + +void f71805f_pnp_enable(struct device *dev) +{ + pnp_enter_conf_state(dev); + pnp_set_logical_device(dev); + pnp_set_enable(dev, dev->enabled) + pnp_exit_conf_state(dev); +} + +static void f71805f_init(struct device *dev) +{ + struct superio_smsc_f71805f_config *conf = dev->chip_info; + struct resource *res0, *res1; + + if (!dev->enabled) + return; + + switch (dev->path.u.pnp.device) { + case F71805F_SP1: + res0 = find_resource(dev, PNP_IDX_IO0); + //TODO: needed? fix or remove? + //init_uart8250(res0->base, &conf->sp1); + break; + + case F71805F_SP2: + res1 = find_resource(dev, PNP_IDX_IO0); + //init_uart8250(res0->base, &conf->sp2); + break; + + /* No KBC on F71805f */ + } +} + +static struct device_operations ops; +static struct pnp_info pnp_dev_info[] = { + { &ops, F71805F_SP1, PNP_IO0 | PNP_IRQ0, { 0x7f8, 0 }, }, + { &ops, F71805F_SP2, PNP_IO0 | PNP_IRQ0, { 0x7f8, 0 }, }, + /* TODO: Everything else */ +}; + +static void phase2_setup_scan_bus(struct device *dev) +{ + pnp_enable_devices(dev, &ops, ARRAY_SIZE(pnp_dev_info), pnp_dev_info); +} + +static struct device_operations ops = { + .phase2_setup_scan_bus = phase2_setup_scan_bus, + .phase4_read_resources = pnp_read_resources, + .phase4_set_resources = f71805f_pnp_set_resources, + .phase4_enable_disable = f71805f_pnp_enable_resources, + .phase5_enable_resources = f71805f_pnp_enable, + .phase6_init = f71805f_init, +};