toshiba.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
  2. /* toshiba.h -- Linux driver for accessing the SMM on Toshiba laptops
  3. *
  4. * Copyright (c) 1996-2000 Jonathan A. Buzzard (jonathan@buzzard.org.uk)
  5. * Copyright (c) 2015 Azael Avalos <coproscefalo@gmail.com>
  6. *
  7. * Thanks to Juergen Heinzl <juergen@monocerus.demon.co.uk> for the pointers
  8. * on making sure the structure is aligned and packed.
  9. *
  10. * This program is free software; you can redistribute it and/or modify it
  11. * under the terms of the GNU General Public License as published by the
  12. * Free Software Foundation; either version 2, or (at your option) any
  13. * later version.
  14. *
  15. * This program is distributed in the hope that it will be useful, but
  16. * WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  18. * General Public License for more details.
  19. *
  20. */
  21. #ifndef _UAPI_LINUX_TOSHIBA_H
  22. #define _UAPI_LINUX_TOSHIBA_H
  23. /*
  24. * Toshiba modules paths
  25. */
  26. #define TOSH_PROC "/proc/toshiba"
  27. #define TOSH_DEVICE "/dev/toshiba"
  28. #define TOSHIBA_ACPI_PROC "/proc/acpi/toshiba"
  29. #define TOSHIBA_ACPI_DEVICE "/dev/toshiba_acpi"
  30. /*
  31. * Toshiba SMM structure
  32. */
  33. typedef struct {
  34. unsigned int eax;
  35. unsigned int ebx __attribute__ ((packed));
  36. unsigned int ecx __attribute__ ((packed));
  37. unsigned int edx __attribute__ ((packed));
  38. unsigned int esi __attribute__ ((packed));
  39. unsigned int edi __attribute__ ((packed));
  40. } SMMRegisters;
  41. /*
  42. * IOCTLs (0x90 - 0x91)
  43. */
  44. #define TOSH_SMM _IOWR('t', 0x90, SMMRegisters)
  45. /*
  46. * Convenience toshiba_acpi command.
  47. *
  48. * The System Configuration Interface (SCI) is opened/closed internally
  49. * to avoid userspace of buggy BIOSes.
  50. *
  51. * The toshiba_acpi module checks whether the eax register is set with
  52. * SCI_GET (0xf300) or SCI_SET (0xf400), returning -EINVAL if not.
  53. */
  54. #define TOSHIBA_ACPI_SCI _IOWR('t', 0x91, SMMRegisters)
  55. #endif /* _UAPI_LINUX_TOSHIBA_H */