cvs commit: src/sys/i386/acpica acpi_toshiba.c src/sys/conf src/sys/modules/acpi/acpi_toshiba Makefile

Nate Lawson nate at root.org
Sun Jan 11 11:27:33 PST 2004


This is still a work in progress but it's gotten far enough that wider
testing is needed.  We're interested in testing on various Toshiba
equipment, post results to acpi-jp at jp.freebsd.org

I'll be gone until tonight so feel free to fix any compilation problems if
I missed something.

-Nate

On Sun, 11 Jan 2004, Nate Lawson wrote:

> njl         2004/01/11 11:18:38 PST
>
>   FreeBSD src repository
>
>   Modified files:
>     sys/conf             files.i386
>     sys/i386/conf        NOTES
>   Added files:
>     sys/i386/acpica      acpi_toshiba.c
>     sys/modules/acpi/acpi_toshiba Makefile
>   Log:
>   Add the ACPI Toshiba extras driver (hotkeys, LCD backlight, video output,
>   forced fan control, and CPU throttling).
>
>   Submitted by:   Hiroyuki Aizu <aizu at navi.org>
>
>   Revision  Changes    Path
>   1.461     +1 -0      src/sys/conf/files.i386
>   1.1       +485 -0    src/sys/i386/acpica/acpi_toshiba.c (new)
>   1.1113    +4 -0      src/sys/i386/conf/NOTES
>   1.1       +9 -0      src/sys/modules/acpi/acpi_toshiba/Makefile (new)
>
>
> Index: src/sys/conf/files.i386
> diff -u src/sys/conf/files.i386:1.460 src/sys/conf/files.i386:1.461
> --- src/sys/conf/files.i386:1.460	Thu Dec 11 14:34:36 2003
> +++ src/sys/conf/files.i386	Sun Jan 11 11:18:38 2004
> @@ -1,7 +1,7 @@
>  # This file tells config what files go into building a kernel,
>  # files marked standard are always included.
>  #
> -# $FreeBSD: /repoman/r/ncvs/src/sys/conf/files.i386,v 1.460 2003/12/11 22:34:36 wpaul Exp $
> +# $FreeBSD: /repoman/r/ncvs/src/sys/conf/files.i386,v 1.461 2004/01/11 19:18:38 njl Exp $
>  #
>  # The long compile-with and dependency lines are required because of
>  # limitations in config: backslash-newline doesn't work in strings, and
> @@ -168,6 +168,7 @@
>  geom/geom_mbr_enc.c		standard
>  i386/acpica/OsdEnvironment.c	optional	acpi
>  i386/acpica/acpi_machdep.c	optional	acpi
> +i386/acpica/acpi_toshiba.c	optional	acpi_toshiba acpi
>  i386/acpica/acpi_wakeup.c	optional	acpi
>  acpi_wakecode.h			optional	acpi			\
>  	dependency 	"$S/i386/acpica/acpi_wakecode.S"		\
> Index: src/sys/i386/acpica/acpi_toshiba.c
> diff -u /dev/null src/sys/i386/acpica/acpi_toshiba.c:1.1
> --- /dev/null	Sun Jan 11 11:18:53 2004
> +++ src/sys/i386/acpica/acpi_toshiba.c	Sun Jan 11 11:18:38 2004
> @@ -0,0 +1,485 @@
> +/*-
> + * Copyright (c) 2003 Hiroyuki Aizu <aizu at navi.org>
> + * All rights reserved.
> + *
> + * Redistribution and use in source and binary forms, with or without
> + * modification, are permitted provided that the following conditions
> + * are met:
> + * 1. Redistributions of source code must retain the above copyright
> + *    notice, this list of conditions and the following disclaimer.
> + * 2. Redistributions in binary form must reproduce the above copyright
> + *    notice, this list of conditions and the following disclaimer in the
> + *    documentation and/or other materials provided with the distribution.
> + *
> + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
> + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
> + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
> + * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
> + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
> + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
> + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
> + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
> + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
> + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
> + * SUCH DAMAGE.
> + *
> + */
> +
> +#include <sys/cdefs.h>
> +__FBSDID("$FreeBSD: /repoman/r/ncvs/src/sys/i386/acpica/acpi_toshiba.c,v 1.1 2004/01/11 19:18:38 njl Exp $");
> +
> +#include "opt_acpi.h"
> +#include <sys/param.h>
> +#include <sys/kernel.h>
> +#include <sys/bus.h>
> +
> +#include "acpi.h"
> +#include <dev/acpica/acpivar.h>
> +
> +#define _COMPONENT      ACPI_TOSHIBA
> +ACPI_MODULE_NAME("TOSHIBA")
> +
> +/*
> + * Toshiba HCI interface definitions
> + *
> + * HCI is Toshiba's "Hardware Control Interface" which is supposed to
> + * be uniform across all their models.  Ideally we would just call
> + * dedicated ACPI methods instead of using this primitive interface.
> + * However, the ACPI methods seem to be incomplete in some areas (for
> + * example they allow setting, but not reading, the LCD brightness
> + * value), so this is still useful.
> + */
> +
> +#define METHOD_HCI		"GHCI"
> +#define METHOD_HCI_ENABLE	"ENAB"
> +
> +/* Operations */
> +#define HCI_SET				0xFF00
> +#define HCI_GET				0xFE00
> +
> +/* Return codes */
> +#define HCI_SUCCESS			0x0000
> +#define HCI_FAILURE			0x1000
> +#define HCI_NOT_SUPPORTED		0x8000
> +#define HCI_EMPTY			0x8C00
> +
> +/* Functions */
> +#define HCI_REG_LCD_BACKLIGHT		0x0002
> +#define HCI_REG_FAN			0x0004
> +#define HCI_REG_SYSTEM_EVENT		0x0016
> +#define HCI_REG_VIDEO_OUTPUT		0x001C
> +#define HCI_REG_HOTKEY_EVENT		0x001E
> +#define HCI_REG_LCD_BRIGHTNESS		0x002A
> +#define HCI_REG_CPU_SPEED		0x0032
> +
> +/* Field definitions */
> +#define HCI_FAN_SHIFT			7
> +#define HCI_LCD_BRIGHTNESS_BITS		3
> +#define HCI_LCD_BRIGHTNESS_SHIFT	(16 - HCI_LCD_BRIGHTNESS_BITS)
> +#define HCI_LCD_BRIGHTNESS_MAX		((1 << HCI_LCD_BRIGHTNESS_BITS) - 1)
> +#define HCI_VIDEO_OUTPUT_FLAG		0x0100
> +#define HCI_VIDEO_OUTPUT_LCD		0x1
> +#define HCI_VIDEO_OUTPUT_CRT		0x2
> +#define HCI_VIDEO_OUTPUT_TV		0x4
> +#define HCI_CPU_SPEED_BITS		3
> +#define HCI_CPU_SPEED_SHIFT		(16 - HCI_CPU_SPEED_BITS)
> +#define HCI_CPU_SPEED_MAX		((1 << HCI_CPU_SPEED_BITS) - 1)
> +
> +/* Key press/release events. */
> +#define FN_F1_PRESS	0x013B
> +#define FN_F1_RELEASE	0x01BB
> +#define FN_F2_PRESS	0x013C
> +#define FN_F2_RELEASE	0x01BC
> +#define FN_F3_PRESS	0x013D
> +#define FN_F3_RELEASE	0x01BD
> +#define FN_F4_PRESS	0x013E
> +#define FN_F4_RELEASE	0x01BE
> +#define FN_F5_PRESS	0x013F
> +#define FN_F5_RELEASE	0x01BF
> +#define FN_F6_PRESS	0x0140
> +#define FN_F6_RELEASE	0x01C0
> +#define FN_F7_PRESS	0x0141
> +#define FN_F7_RELEASE	0x01C1
> +#define FN_F8_PRESS	0x0142
> +#define FN_F8_RELEASE	0x01C2
> +#define FN_F9_PRESS	0x0143
> +#define FN_F9_RELEASE	0x01C3
> +#define FN_BS_PRESS	0x010E
> +#define FN_BS_RELEASE	0x018E
> +#define FN_ESC_PRESS	0x0101
> +#define FN_ESC_RELEASE	0x0181
> +#define FN_KNJ_PRESS	0x0129
> +#define FN_KNJ_RELEASE	0x01A9
> +
> +/* HCI register definitions. */
> +#define HCI_WORDS	6		/* Number of registers */
> +#define HCI_REG_AX	0		/* Operation, then return value */
> +#define HCI_REG_BX	1		/* Function */
> +#define HCI_REG_CX	2		/* Argument (in or out) */
> +#define HCI_REG_DX	3		/* Unused? */
> +#define HCI_REG_SI	4		/* Unused? */
> +#define HCI_REG_DI	5		/* Unused? */
> +
> +struct acpi_toshiba_softc {
> +	device_t	dev;
> +	ACPI_HANDLE	handle;
> +	struct		sysctl_ctx_list sysctl_ctx;
> +	struct		sysctl_oid *sysctl_tree;
> +};
> +
> +/* Prototype for HCI functions for getting/setting a value. */
> +typedef int	hci_fn_t(ACPI_HANDLE, int, UINT32 *);
> +
> +static int	acpi_toshiba_probe(device_t dev);
> +static int	acpi_toshiba_attach(device_t dev);
> +static int	acpi_toshiba_detach(device_t dev);
> +static int	acpi_toshiba_sysctl(SYSCTL_HANDLER_ARGS);
> +static hci_fn_t	hci_force_fan;
> +static hci_fn_t	hci_video_output;
> +static hci_fn_t	hci_lcd_brightness;
> +static hci_fn_t	hci_lcd_backlight;
> +static hci_fn_t	hci_cpu_speed;
> +static int	hci_call(ACPI_HANDLE h, int op, int function, UINT32 *arg);
> +static void	hci_key_action(ACPI_HANDLE h, UINT32 key);
> +static void	acpi_toshiba_notify(ACPI_HANDLE h, UINT32 notify,
> +				    void *context);
> +
> +/* Table of sysctl names and HCI functions to call. */
> +static struct {
> +	char		*name;
> +	hci_fn_t	*handler;
> +} sysctl_table[] = {
> +	/* name,		handler */
> +	{"force_fan",		hci_force_fan},
> +	{"cpu_speed",		hci_cpu_speed},
> +	{"video_output",	hci_video_output},
> +	{"lcd_backlight",	hci_lcd_backlight},
> +	{"lcd_brightness",	hci_lcd_brightness},
> +	{NULL, NULL}
> +};
> +
> +static device_method_t acpi_toshiba_methods[] = {
> +	DEVMETHOD(device_probe,		acpi_toshiba_probe),
> +	DEVMETHOD(device_attach,	acpi_toshiba_attach),
> +	DEVMETHOD(device_detach,	acpi_toshiba_detach),
> +
> +	{0, 0}
> +};
> +
> +static driver_t acpi_toshiba_driver = {
> +	"acpi_toshiba",
> +	acpi_toshiba_methods,
> +	sizeof(struct acpi_toshiba_softc),
> +};
> +
> +static devclass_t acpi_toshiba_devclass;
> +DRIVER_MODULE(acpi_toshiba, acpi, acpi_toshiba_driver, acpi_toshiba_devclass,
> +	      0, 0);
> +MODULE_DEPEND(acpi_toshiba, acpi, 100, 100, 100);
> +
> +static int	enable_fn_keys = 1;
> +TUNABLE_INT("hw.acpi.toshiba.enable_fn_keys", &enable_fn_keys);
> +
> +/*
> + * HID      Model
> + * -------------------------------------
> + * TOS6200  Libretto L Series
> + *          Dynabook Satellite 2455
> + *          Dynabook SS 3500
> + * TOS6207  Dynabook SS2110 Series
> + */
> +static int
> +acpi_toshiba_probe(device_t dev)
> +{
> +	int ret = ENXIO;
> +
> +	if (!acpi_disabled("toshiba") &&
> +	    acpi_get_type(dev) == ACPI_TYPE_DEVICE &&
> +	    device_get_unit(dev) == 0 &&
> +	    (acpi_MatchHid(dev, "TOS6200") ||
> +	     acpi_MatchHid(dev, "TOS6207"))) {
> +		device_set_desc(dev, "Toshiba Extra HCI");
> +		ret = 0;
> +	}
> +
> +	return (ret);
> +}
> +
> +static int
> +acpi_toshiba_attach(device_t dev)
> +{
> +	struct		acpi_toshiba_softc *sc;
> +	struct		acpi_softc *acpi_sc;
> +	ACPI_STATUS	status;
> +	int		i;
> +
> +	ACPI_FUNCTION_TRACE((char *)(uintptr_t)__func__);
> +
> +	sc = device_get_softc(dev);
> +	sc->dev = dev;
> +	sc->handle = acpi_get_handle(dev);
> +
> +	acpi_sc = acpi_device_get_parent_softc(dev);
> +	sysctl_ctx_init(&sc->sysctl_ctx);
> +	sc->sysctl_tree = SYSCTL_ADD_NODE(&sc->sysctl_ctx,
> +	    SYSCTL_CHILDREN(acpi_sc->acpi_sysctl_tree), OID_AUTO,
> +	    "toshiba", CTLFLAG_RD, 0, "");
> +
> +	for (i = 0; sysctl_table[i].name != NULL; i++) {
> +		SYSCTL_ADD_PROC(&sc->sysctl_ctx,
> +		    SYSCTL_CHILDREN(sc->sysctl_tree), OID_AUTO,
> +		    sysctl_table[i].name,
> +		    CTLTYPE_INT | CTLFLAG_RW | CTLFLAG_ANYBODY,
> +		    sc, i, acpi_toshiba_sysctl, "I", "");
> +	}
> +
> +	if (enable_fn_keys != 0) {
> +		status = AcpiEvaluateObject(sc->handle, METHOD_HCI_ENABLE,
> +					    NULL, NULL);
> +		if (ACPI_FAILURE(status)) {
> +			device_printf(dev, "enable FN keys failed\n");
> +			sysctl_ctx_free(&sc->sysctl_ctx);
> +			return (ENXIO);
> +		}
> +		AcpiInstallNotifyHandler(sc->handle, ACPI_DEVICE_NOTIFY,
> +					 acpi_toshiba_notify, sc);
> +	}
> +
> +	return (0);
> +}
> +
> +static int
> +acpi_toshiba_detach(device_t dev)
> +{
> +	struct		acpi_toshiba_softc *sc;
> +
> +	ACPI_FUNCTION_TRACE((char *)(uintptr_t)__func__);
> +
> +	sc = device_get_softc(dev);
> +	AcpiRemoveNotifyHandler(sc->handle, ACPI_DEVICE_NOTIFY,
> +				acpi_toshiba_notify);
> +	sysctl_ctx_free(&sc->sysctl_ctx);
> +
> +	return (0);
> +}
> +
> +static int
> +acpi_toshiba_sysctl(SYSCTL_HANDLER_ARGS)
> +{
> +	struct		acpi_toshiba_softc *sc;
> +	UINT32		arg;
> +	int		function, error = 0;
> +	hci_fn_t	*handler;
> +
> +	sc = (struct acpi_toshiba_softc *)oidp->oid_arg1;
> +	function = oidp->oid_arg2;
> +	handler = sysctl_table[function].handler;
> +
> +	/* Get the current value from the appropriate function. */
> +	error = handler(sc->handle, HCI_GET, &arg);
> +	if (error != 0)
> +		return (error);
> +
> +	/* Send the current value to the user and return if no new value. */
> +	error = sysctl_handle_int(oidp, &arg, 0, req);
> +	if (error != 0 || req->newptr == NULL)
> +		return (error);
> +
> +	/* Set the new value via the appropriate function. */
> +	error = handler(sc->handle, HCI_SET, &arg);
> +
> +	return (error);
> +}
> +
> +static int
> +hci_force_fan(ACPI_HANDLE h, int op, UINT32 *state)
> +{
> +	int		ret;
> +
> +	if (op == HCI_SET) {
> +		if (*state < 0 || *state > 1)
> +			return (EINVAL);
> +		*state <<= HCI_FAN_SHIFT;
> +	}
> +	ret = hci_call(h, op, HCI_REG_FAN, state);
> +	if (ret == 0 && op == HCI_GET)
> +		*state >>= HCI_FAN_SHIFT;
> +	return (ret);
> +}
> +
> +static int
> +hci_video_output(ACPI_HANDLE h, int op, UINT32 *video_output)
> +{
> +	int		ret;
> +
> +	if (op == HCI_SET) {
> +		if (*video_output < 1 || *video_output > 7)
> +			return (EINVAL);
> +		*video_output |= HCI_VIDEO_OUTPUT_FLAG;
> +	}
> +	ret = hci_call(h, op, HCI_REG_VIDEO_OUTPUT, video_output);
> +	if (ret == 0 && op == HCI_GET)
> +		*video_output &= 0xff;
> +	return (ret);
> +}
> +
> +static int
> +hci_lcd_brightness(ACPI_HANDLE h, int op, UINT32 *brightness)
> +{
> +	int		ret;
> +
> +	if (op == HCI_SET) {
> +		if (*brightness < 0 || *brightness > HCI_LCD_BRIGHTNESS_MAX)
> +			return (EINVAL);
> +		*brightness <<= HCI_LCD_BRIGHTNESS_SHIFT;
> +	}
> +	ret = hci_call(h, op, HCI_REG_LCD_BRIGHTNESS, brightness);
> +	if (ret == 0 && op == HCI_GET)
> +		*brightness >>= HCI_LCD_BRIGHTNESS_SHIFT;
> +	return (ret);
> +}
> +
> +static int
> +hci_lcd_backlight(ACPI_HANDLE h, int op, UINT32 *backlight)
> +{
> +	if (op == HCI_SET) {
> +		if (*backlight < 0 || *backlight > 1)
> +			return (EINVAL);
> +	}
> +	return (hci_call(h, op, HCI_REG_LCD_BACKLIGHT, backlight));
> +}
> +
> +static int
> +hci_cpu_speed(ACPI_HANDLE h, int op, UINT32 *speed)
> +{
> +	int		ret;
> +
> +	if (op == HCI_SET) {
> +		if (*speed < 0 || *speed > HCI_CPU_SPEED_MAX)
> +			return (EINVAL);
> +		*speed <<= HCI_CPU_SPEED_SHIFT;
> +	}
> +	ret = hci_call(h, op, HCI_REG_CPU_SPEED, speed);
> +	if (ret == 0 && op == HCI_GET)
> +		*speed >>= HCI_CPU_SPEED_SHIFT;
> +	return (ret);
> +}
> +
> +static int
> +hci_call(ACPI_HANDLE h, int op, int function, UINT32 *arg)
> +{
> +	ACPI_OBJECT_LIST args;
> +	ACPI_BUFFER	results;
> +	ACPI_OBJECT	obj[HCI_WORDS];
> +	ACPI_OBJECT	*res;
> +	int		status, i, ret;
> +
> +	status = ENXIO;
> +
> +	for (i = 0; i < HCI_WORDS; i++) {
> +		obj[i].Type = ACPI_TYPE_INTEGER;
> +		obj[i].Integer.Value = 0;
> +	}
> +	obj[HCI_REG_AX].Integer.Value = op;
> +	obj[HCI_REG_BX].Integer.Value = function;
> +	if (op == HCI_SET)
> +		obj[HCI_REG_CX].Integer.Value = *arg;
> +
> +	args.Count = HCI_WORDS;
> +	args.Pointer = obj;
> +	results.Pointer = NULL;
> +	results.Length = ACPI_ALLOCATE_BUFFER;
> +	if (ACPI_FAILURE(AcpiEvaluateObject(h, METHOD_HCI, &args, &results)))
> +		goto end;
> +	res = (ACPI_OBJECT *)results.Pointer;
> +	if (!ACPI_PKG_VALID(res, HCI_WORDS)) {
> +		printf("toshiba: invalid package!\n");
> +		return (ENXIO);
> +	}
> +
> +	acpi_PkgInt32(res, HCI_REG_AX, &ret);
> +	if (ret == HCI_SUCCESS) {
> +		if (op == HCI_GET)
> +			acpi_PkgInt32(res, HCI_REG_CX, arg);
> +		status = 0;
> +	} else if (function == HCI_REG_SYSTEM_EVENT && op == HCI_GET &&
> +	    ret == HCI_NOT_SUPPORTED) {
> +		/*
> +		 * Sometimes system events are disabled without us requesting
> +		 * it.  This workaround attempts to re-enable them.
> +		 */
> +		 i = 1;
> +		 hci_call(h, HCI_SET, HCI_REG_SYSTEM_EVENT, &i);
> +	}
> +
> +end:
> +	if (results.Pointer != NULL)
> +		AcpiOsFree(results.Pointer);
> +
> +	return (status);
> +}
> +
> +/*
> + * Perform a few actions based on the keypress.  Users can extend this
> + * functionality by reading the keystrokes we send to devd(8).
> + */
> +static void
> +hci_key_action(ACPI_HANDLE h, UINT32 key)
> +{
> +	UINT32		arg;
> +
> +	switch (key) {
> +	case FN_F6_RELEASE:
> +		/* Decrease LCD brightness. */
> +		hci_lcd_brightness(h, HCI_GET, &arg);
> +		if (arg-- == 0)
> +			arg = 0;
> +		else
> +			hci_lcd_brightness(h, HCI_SET, &arg);
> +		break;
> +	case FN_F7_RELEASE:
> +		/* Increase LCD brightness. */
> +		hci_lcd_brightness(h, HCI_GET, &arg);
> +		if (arg++ == 7)
> +			arg = 7;
> +		else
> +			hci_lcd_brightness(h, HCI_SET, &arg);
> +		break;
> +	case FN_F5_RELEASE:
> +		/* Cycle through video outputs. */
> +		hci_video_output(h, HCI_GET, &arg);
> +		arg = (arg + 1) % 7;
> +		hci_video_output(h, HCI_SET, &arg);
> +		break;
> +	case FN_F8_RELEASE:
> +		/* Toggle LCD backlight. */
> +		hci_lcd_backlight(h, HCI_GET, &arg);
> +		arg = (arg != 0) ? 0 : 1;
> +		hci_lcd_backlight(h, HCI_SET, &arg);
> +		break;
> +	case FN_ESC_RELEASE:
> +		/* Toggle forcing fan on. */
> +		hci_force_fan(h, HCI_GET, &arg);
> +		arg = (arg != 0) ? 0 : 1;
> +		hci_force_fan(h, HCI_SET, &arg);
> +		break;
> +	}
> +}
> +
> +static void
> +acpi_toshiba_notify(ACPI_HANDLE h, UINT32 notify, void *context)
> +{
> +	struct		acpi_toshiba_softc *sc;
> +	UINT32		key;
> +
> +	sc = (struct acpi_toshiba_softc *)context;
> +
> +	if (notify == 0x80) {
> +		while (hci_call(h, HCI_GET, HCI_REG_SYSTEM_EVENT, &key) == 0) {
> +			hci_key_action(h, key);
> +			acpi_UserNotify("TOSHIBA", h, (uint8_t)key);
> +		}
> +	} else {
> +		device_printf(sc->dev, "unknown notify: 0x%x\n", notify);
> +	}
> +}
> Index: src/sys/i386/conf/NOTES
> diff -u src/sys/i386/conf/NOTES:1.1112 src/sys/i386/conf/NOTES:1.1113
> --- src/sys/i386/conf/NOTES:1.1112	Sat Jan  3 10:43:37 2004
> +++ src/sys/i386/conf/NOTES	Sun Jan 11 11:18:38 2004
> @@ -4,7 +4,7 @@
>  # This file contains machine dependent kernel configuration notes.  For
>  # machine independent notes, look in /sys/conf/NOTES.
>  #
> -# $FreeBSD: /repoman/r/ncvs/src/sys/i386/conf/NOTES,v 1.1112 2004/01/03 18:43:37 phk Exp $
> +# $FreeBSD: /repoman/r/ncvs/src/sys/i386/conf/NOTES,v 1.1113 2004/01/11 19:18:38 njl Exp $
>  #
>
>  #
> @@ -442,6 +442,10 @@
>  options 	ACPI_MAX_THREADS=1
>  #!options 	ACPI_NO_SEMAPHORES
>  #!options 	ACPICA_PEDANTIC
> +
> +# ACPI Toshiba Extras (LCD backlight/brightness, video output, etc.)
> +#
> +device		acpi_toshiba
>
>  # DRM options:
>  # mgadrm:    AGP Matrox G200, G400, G450, G550
> Index: src/sys/modules/acpi/acpi_toshiba/Makefile
> diff -u /dev/null src/sys/modules/acpi/acpi_toshiba/Makefile:1.1
> --- /dev/null	Sun Jan 11 11:18:53 2004
> +++ src/sys/modules/acpi/acpi_toshiba/Makefile	Sun Jan 11 11:18:38 2004
> @@ -0,0 +1,9 @@
> +# $FreeBSD: /repoman/r/ncvs/src/sys/modules/acpi/acpi_toshiba/Makefile,v 1.1 2004/01/11 19:18:38 njl Exp $
> +
> +.PATH:		${.CURDIR}/../../../i386/acpica
> +
> +KMOD=		acpi_toshiba
> +CFLAGS+=	-I${.CURDIR}/../../../contrib/dev/acpica
> +SRCS=		acpi_toshiba.c opt_acpi.h device_if.h bus_if.h
> +
> +.include <bsd.kmod.mk>
>


More information about the cvs-all mailing list