linux/drivers/firmware/pcdp.h
<<
>>
Prefs
   1/*
   2 * Definitions for PCDP-defined console devices
   3 *
   4 * For DIG64_HCDPv10a_01.pdf and DIG64_PCDPv20.pdf (v1.0a and v2.0 resp.),
   5 * please see <http://www.dig64.org/specifications/>
   6 *
   7 * (c) Copyright 2002, 2004 Hewlett-Packard Development Company, L.P.
   8 *      Khalid Aziz <khalid.aziz@hp.com>
   9 *      Bjorn Helgaas <bjorn.helgaas@hp.com>
  10 *
  11 * This program is free software; you can redistribute it and/or modify
  12 * it under the terms of the GNU General Public License version 2 as
  13 * published by the Free Software Foundation.
  14 */
  15
  16#define PCDP_CONSOLE                    0
  17#define PCDP_DEBUG                      1
  18#define PCDP_CONSOLE_OUTPUT             2
  19#define PCDP_CONSOLE_INPUT              3
  20
  21#define PCDP_UART                       (0 << 3)
  22#define PCDP_VGA                        (1 << 3)
  23#define PCDP_USB                        (2 << 3)
  24
  25/* pcdp_uart.type and pcdp_device.type */
  26#define PCDP_CONSOLE_UART               (PCDP_UART | PCDP_CONSOLE)
  27#define PCDP_DEBUG_UART                 (PCDP_UART | PCDP_DEBUG)
  28#define PCDP_CONSOLE_VGA                (PCDP_VGA  | PCDP_CONSOLE_OUTPUT)
  29#define PCDP_CONSOLE_USB                (PCDP_USB  | PCDP_CONSOLE_INPUT)
  30
  31/* pcdp_uart.flags */
  32#define PCDP_UART_EDGE_SENSITIVE        (1 << 0)
  33#define PCDP_UART_ACTIVE_LOW            (1 << 1)
  34#define PCDP_UART_PRIMARY_CONSOLE       (1 << 2)
  35#define PCDP_UART_IRQ                   (1 << 6) /* in pci_func for rev < 3 */
  36#define PCDP_UART_PCI                   (1 << 7) /* in pci_func for rev < 3 */
  37
  38struct pcdp_uart {
  39        u8                              type;
  40        u8                              bits;
  41        u8                              parity;
  42        u8                              stop_bits;
  43        u8                              pci_seg;
  44        u8                              pci_bus;
  45        u8                              pci_dev;
  46        u8                              pci_func;
  47        u64                             baud;
  48        struct acpi_generic_address     addr;
  49        u16                             pci_dev_id;
  50        u16                             pci_vendor_id;
  51        u32                             gsi;
  52        u32                             clock_rate;
  53        u8                              pci_prog_intfc;
  54        u8                              flags;
  55        u16                             conout_index;
  56        u32                             reserved;
  57} __attribute__((packed));
  58
  59#define PCDP_IF_PCI     1
  60
  61/* pcdp_if_pci.trans */
  62#define PCDP_PCI_TRANS_IOPORT   0x02
  63#define PCDP_PCI_TRANS_MMIO     0x01
  64
  65struct pcdp_if_pci {
  66        u8                      interconnect;
  67        u8                      reserved;
  68        u16                     length;
  69        u8                      segment;
  70        u8                      bus;
  71        u8                      dev;
  72        u8                      fun;
  73        u16                     dev_id;
  74        u16                     vendor_id;
  75        u32                     acpi_interrupt;
  76        u64                     mmio_tra;
  77        u64                     ioport_tra;
  78        u8                      flags;
  79        u8                      trans;
  80} __attribute__((packed));
  81
  82struct pcdp_vga {
  83        u8                      count;          /* address space descriptors */
  84} __attribute__((packed));
  85
  86/* pcdp_device.flags */
  87#define PCDP_PRIMARY_CONSOLE    1
  88
  89struct pcdp_device {
  90        u8                      type;
  91        u8                      flags;
  92        u16                     length;
  93        u16                     efi_index;
  94        /* next data is pcdp_if_pci or pcdp_if_acpi (not yet supported) */
  95        /* next data is device specific type (currently only pcdp_vga) */
  96} __attribute__((packed));
  97
  98struct pcdp {
  99        u8                      signature[4];
 100        u32                     length;
 101        u8                      rev;            /* PCDP v2.0 is rev 3 */
 102        u8                      chksum;
 103        u8                      oemid[6];
 104        u8                      oem_tabid[8];
 105        u32                     oem_rev;
 106        u8                      creator_id[4];
 107        u32                     creator_rev;
 108        u32                     num_uarts;
 109        struct pcdp_uart        uart[0];        /* actual size is num_uarts */
 110        /* remainder of table is pcdp_device structures */
 111} __attribute__((packed));
 112