Annotation of qemu/roms/qemu-palcode/pci.h, revision 1.1.1.1

1.1       root        1: /* Simplistic PCI support.
                      2: 
                      3:    Copyright (C) 2011 Richard Henderson
                      4: 
                      5:    This file is part of QEMU PALcode.
                      6: 
                      7:    This program is free software; you can redistribute it and/or modify
                      8:    it under the terms of the GNU General Public License as published by
                      9:    the Free Software Foundation; either version 2 of the License or
                     10:    (at your option) any later version.
                     11: 
                     12:    This program is distributed in the hope that it will be useful,
                     13:    but WITHOUT ANY WARRANTY; without even the implied warranty of
                     14:    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the text
                     15:    of the GNU General Public License for more details.
                     16: 
                     17:    You should have received a copy of the GNU General Public License
                     18:    along with this program; see the file COPYING.  If not see
                     19:    <http://www.gnu.org/licenses/>.  */
                     20: 
                     21: /* This header is intended to be compatible with the pci.h from SeaBIOS.
                     22:    Their header, however, is too PC specific to be of use.  */
                     23: 
                     24: #ifndef PCI_H
                     25: #define PCI_H 1
                     26: 
                     27: extern void *pci_conf_base;
                     28: 
                     29: static inline void pci_config_writel(int bdf, uint8_t addr, uint32_t val)
                     30: {
                     31:   *(volatile uint32_t *)(pci_conf_base + bdf * 256 + addr) = val;
                     32: }
                     33: 
                     34: static inline void pci_config_writew(int bdf, uint8_t addr, uint16_t val)
                     35: {
                     36:   *(volatile uint16_t *)(pci_conf_base + bdf * 256 + addr) = val;
                     37: }
                     38: 
                     39: static inline void pci_config_writeb(int bdf, uint8_t addr, uint8_t val)
                     40: {
                     41:   *(volatile uint8_t *)(pci_conf_base + bdf * 256 + addr) = val;
                     42: }
                     43: 
                     44: static inline uint32_t pci_config_readl(int bdf, uint8_t addr)
                     45: {
                     46:   return *(volatile uint32_t *)(pci_conf_base + bdf * 256 + addr);
                     47: }
                     48: 
                     49: static inline uint16_t pci_config_readw(int bdf, uint8_t addr)
                     50: {
                     51:   return *(volatile uint16_t *)(pci_conf_base + bdf * 256 + addr);
                     52: }
                     53: 
                     54: static inline uint8_t pci_config_readb(int bdf, uint8_t addr)
                     55: {
                     56:   return *(volatile uint8_t *)(pci_conf_base + bdf * 256 + addr);
                     57: }
                     58: 
                     59: extern void pci_config_maskw(int bdf, int addr, uint16_t off, uint16_t on);
                     60: 
                     61: extern int pci_next(int bdf, int *pmax);
                     62: 
                     63: #define foreachpci(BDF, MAX)                           \
                     64:        for (MAX = 0x0100, BDF = pci_next(0, &MAX);     \
                     65:             BDF >= 0;                                  \
                     66:             BDF = pci_next(BDF+1, &MAX))
                     67: 
                     68: #endif /* PCI_H */

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.