LCOV - code coverage report
Current view: top level - arch/x86/pci - early.c (source / functions) Hit Total Coverage
Test: combined.info Lines: 17 29 58.6 %
Date: 2022-03-28 13:20:08 Functions: 4 7 57.1 %
Branches: 0 0 -

           Branch data     Line data    Source code
       1                 :            : // SPDX-License-Identifier: GPL-2.0
       2                 :            : #include <linux/kernel.h>
       3                 :            : #include <linux/pci.h>
       4                 :            : #include <asm/pci-direct.h>
       5                 :            : #include <asm/io.h>
       6                 :            : #include <asm/pci_x86.h>
       7                 :            : 
       8                 :            : /* Direct PCI access. This is used for PCI accesses in early boot before
       9                 :            :    the PCI subsystem works. */
      10                 :            : 
      11                 :       1140 : u32 read_pci_config(u8 bus, u8 slot, u8 func, u8 offset)
      12                 :            : {
      13                 :       1140 :         u32 v;
      14                 :       1140 :         outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8);
      15                 :       1140 :         v = inl(0xcfc);
      16                 :       1140 :         return v;
      17                 :            : }
      18                 :            : 
      19                 :        180 : u8 read_pci_config_byte(u8 bus, u8 slot, u8 func, u8 offset)
      20                 :            : {
      21                 :        180 :         u8 v;
      22                 :        180 :         outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8);
      23                 :        180 :         v = inb(0xcfc + (offset&3));
      24                 :        180 :         return v;
      25                 :            : }
      26                 :            : 
      27                 :       1380 : u16 read_pci_config_16(u8 bus, u8 slot, u8 func, u8 offset)
      28                 :            : {
      29                 :       1380 :         u16 v;
      30                 :       1380 :         outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8);
      31                 :       1380 :         v = inw(0xcfc + (offset&2));
      32                 :       1380 :         return v;
      33                 :            : }
      34                 :            : 
      35                 :          0 : void write_pci_config(u8 bus, u8 slot, u8 func, u8 offset,
      36                 :            :                                     u32 val)
      37                 :            : {
      38                 :          0 :         outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8);
      39                 :          0 :         outl(val, 0xcfc);
      40                 :          0 : }
      41                 :            : 
      42                 :          0 : void write_pci_config_byte(u8 bus, u8 slot, u8 func, u8 offset, u8 val)
      43                 :            : {
      44                 :          0 :         outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8);
      45                 :          0 :         outb(val, 0xcfc + (offset&3));
      46                 :          0 : }
      47                 :            : 
      48                 :          0 : void write_pci_config_16(u8 bus, u8 slot, u8 func, u8 offset, u16 val)
      49                 :            : {
      50                 :          0 :         outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8);
      51                 :          0 :         outw(val, 0xcfc + (offset&2));
      52                 :          0 : }
      53                 :            : 
      54                 :        150 : int early_pci_allowed(void)
      55                 :            : {
      56                 :        150 :         return (pci_probe & (PCI_PROBE_CONF1|PCI_PROBE_NOEARLY)) ==
      57                 :            :                         PCI_PROBE_CONF1;
      58                 :            : }
      59                 :            : 

Generated by: LCOV version 1.14