Peter Stuge wrote: > On Sun, Oct 28, 2007 at 08:04:26PM -0400, Corey Osgood wrote: > >> +void f71805f_pnp_enable(struct device *dev) >> +{ >> + pnp_enter_conf_state(dev); >> + pnp_set_logical_device(dev); >> + >> + if(dev->enabled) { >> + pnp_set_enable(dev, 1); >> + } >> + else { >> + pnp_set_enable(dev, 0); >> + } >> + pnp_exit_conf_state(dev); >> +} >> > > How about just pnp_set_enable(dev, dev->enabled) ? > > Or !!dev->enabled if it needs to be 1 specifically. >
Ok. > >> +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) { >> > > Since switch isn't a function I think the style is to have a space > before ( though I don't care much for all the spaces myself. > Sounds right to me. > > >> + case F71805F_SP1: >> + res0 = find_resource(dev, PNP_IDX_IO0); >> + //init_uart8250(res0->base, &conf->com1); >> > > Why commented out? Can it be removed? > Good question, wish I could give you a good answer. It was commented in the v2 code, and is also commented in the winbond. I think it's something that should work in the future, but doesn't at the moment. I've put in a comment to that effect. > > >> + /* COM1 */ >> + com1dev = "2"; >> > > Are the ports called COM1 and 2 in the data sheet? They're SP1/2 > above. I don't particularly like the COMn names. > OK. But does renaming them to spn break the dts? Guess we'll find out later. > > >> +++ superio/fintek/f71805f/Makefile (revision 0) >> @@ -0,0 +1,30 @@ >> +## >> +## This file is part of the LinuxBIOS project. >> +## >> +## Copyright (C) 2007 coresystems GmbH >> +## (Written by Stefan Reinauer <[EMAIL PROTECTED]> for coresystems GmbH) >> > > Did Stefan really write this? > Nope, my bad, copy-paste error. Updated patch attached. -Corey
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 <[EMAIL PROTECTED]> Index: Kconfig =================================================================== --- Kconfig (revision 507) +++ Kconfig (working copy) @@ -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 Index: superio/fintek/f71805f/stage1.c =================================================================== --- superio/fintek/f71805f/stage1.c (revision 0) +++ superio/fintek/f71805f/stage1.c (revision 0) @@ -0,0 +1,41 @@ +/* + * This file is part of the LinuxBIOS project. + * + * Copyright 2007 Corey Osgood <[EMAIL PROTECTED]> + * + * 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); +} Index: superio/fintek/f71805f/f71805f.h =================================================================== --- superio/fintek/f71805f/f71805f.h (revision 0) +++ superio/fintek/f71805f/f71805f.h (revision 0) @@ -0,0 +1,36 @@ +/* + * This file is part of the LinuxBIOS project. + * + * Copyright (C) 2007 Corey Osgood <[EMAIL PROTECTED]> + * + * 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) */ Index: superio/fintek/f71805f/superio.c =================================================================== --- superio/fintek/f71805f/superio.c (revision 0) +++ superio/fintek/f71805f/superio.c (revision 0) @@ -0,0 +1,117 @@ +/* + * This file is part of the LinuxBIOS project. + * + * Copyright 2007 Corey Osgood <[EMAIL PROTECTED]> + * + * 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, +}; Index: superio/fintek/f71805f/dts =================================================================== --- superio/fintek/f71805f/dts (revision 0) +++ superio/fintek/f71805f/dts (revision 0) @@ -0,0 +1,53 @@ +/* + * This file is part of the LinuxBIOS project. + * + * Copyright (C) 2007 Corey Osgood <[EMAIL PROTECTED]> + * + * 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"; +}; Index: superio/fintek/f71805f/Makefile =================================================================== --- superio/fintek/f71805f/Makefile (revision 0) +++ superio/fintek/f71805f/Makefile (revision 0) @@ -0,0 +1,29 @@ +## +## This file is part of the LinuxBIOS project. +## +## Copyright (C) 2007 Corey Osgood <[EMAIL PROTECTED]> +## +## 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
-- linuxbios mailing list linuxbios@linuxbios.org http://www.linuxbios.org/mailman/listinfo/linuxbios