/drivers/video/drm/list_sort.c |
---|
File deleted |
/drivers/video/drm/ttm/ttm_global.c |
---|
File deleted |
/drivers/video/drm/ttm/ttm_bo.c |
---|
File deleted |
/drivers/video/drm/drm_dp_i2c_helper.c |
---|
File deleted |
/drivers/video/drm/idr.c |
---|
34,56 → 34,7 |
#include "drmP.h" |
#include "drm_crtc.h" |
unsigned long find_first_bit(const unsigned long *addr, unsigned long size) |
{ |
const unsigned long *p = addr; |
unsigned long result = 0; |
unsigned long tmp; |
while (size & ~(BITS_PER_LONG-1)) { |
if ((tmp = *(p++))) |
goto found; |
result += BITS_PER_LONG; |
size -= BITS_PER_LONG; |
} |
if (!size) |
return result; |
tmp = (*p) & (~0UL >> (BITS_PER_LONG - size)); |
if (tmp == 0UL) /* Are any bits set? */ |
return result + size; /* Nope. */ |
found: |
return result + __ffs(tmp); |
} |
int find_next_bit(const unsigned long *addr, int size, int offset) |
{ |
const unsigned long *p = addr + (offset >> 5); |
int set = 0, bit = offset & 31, res; |
if (bit) |
{ |
/* |
* Look for nonzero in the first 32 bits: |
*/ |
__asm__("bsfl %1,%0\n\t" |
"jne 1f\n\t" |
"movl $32, %0\n" |
"1:" |
: "=r" (set) |
: "r" (*p >> bit)); |
if (set < (32 - bit)) |
return set + offset; |
set = 32 - bit; |
p++; |
} |
/* |
* No set bit yet, search remaining full words for a bit |
*/ |
res = find_first_bit (p, size - 32 * (p - addr)); |
return (offset + set + res); |
} |
#define ACCESS_ONCE(x) (*(volatile typeof(x) *)&(x)) |
#define rcu_dereference(p) ({ \ |
/drivers/video/drm/includes/linux/kernel.h |
---|
78,22 → 78,6 |
(void) (&_max1 == &_max2); \ |
_max1 > _max2 ? _max1 : _max2; }) |
/* |
* ..and if you can't take the strict |
* types, you can specify one yourself. |
* |
* Or not use min/max/clamp at all, of course. |
*/ |
#define min_t(type, x, y) ({ \ |
type __min1 = (x); \ |
type __min2 = (y); \ |
__min1 < __min2 ? __min1: __min2; }) |
#define max_t(type, x, y) ({ \ |
type __max1 = (x); \ |
type __max2 = (y); \ |
__max1 > __max2 ? __max1: __max2; }) |
/** |
* container_of - cast a member of a structure out to the containing structure |
* @ptr: the pointer to the member. |
/drivers/video/drm/includes/linux/sched.h |
---|
1,29 → 1,0 |
/* stub */ |
static inline void mdelay(unsigned long time) |
{ |
time /= 10; |
if(!time) time = 1; |
__asm__ __volatile__ ( |
"call *__imp__Delay" |
::"b" (time)); |
__asm__ __volatile__ ( |
"":::"ebx"); |
}; |
static inline void udelay(unsigned long delay) |
{ |
if(!delay) delay++; |
delay*= 500; |
while(delay--) |
{ |
__asm__ __volatile__( |
"xorl %%eax, %%eax \n\t" |
"cpuid" |
:::"eax","ebx","ecx","edx" ); |
} |
} |
/drivers/video/drm/includes/errno.h |
---|
0,0 → 1,111 |
#ifndef _ASM_GENERIC_ERRNO_H |
#define _ASM_GENERIC_ERRNO_H |
#include <errno-base.h> |
#define EDEADLK 35 /* Resource deadlock would occur */ |
#define ENAMETOOLONG 36 /* File name too long */ |
#define ENOLCK 37 /* No record locks available */ |
#define ENOSYS 38 /* Function not implemented */ |
#define ENOTEMPTY 39 /* Directory not empty */ |
#define ELOOP 40 /* Too many symbolic links encountered */ |
#define EWOULDBLOCK EAGAIN /* Operation would block */ |
#define ENOMSG 42 /* No message of desired type */ |
#define EIDRM 43 /* Identifier removed */ |
#define ECHRNG 44 /* Channel number out of range */ |
#define EL2NSYNC 45 /* Level 2 not synchronized */ |
#define EL3HLT 46 /* Level 3 halted */ |
#define EL3RST 47 /* Level 3 reset */ |
#define ELNRNG 48 /* Link number out of range */ |
#define EUNATCH 49 /* Protocol driver not attached */ |
#define ENOCSI 50 /* No CSI structure available */ |
#define EL2HLT 51 /* Level 2 halted */ |
#define EBADE 52 /* Invalid exchange */ |
#define EBADR 53 /* Invalid request descriptor */ |
#define EXFULL 54 /* Exchange full */ |
#define ENOANO 55 /* No anode */ |
#define EBADRQC 56 /* Invalid request code */ |
#define EBADSLT 57 /* Invalid slot */ |
#define EDEADLOCK EDEADLK |
#define EBFONT 59 /* Bad font file format */ |
#define ENOSTR 60 /* Device not a stream */ |
#define ENODATA 61 /* No data available */ |
#define ETIME 62 /* Timer expired */ |
#define ENOSR 63 /* Out of streams resources */ |
#define ENONET 64 /* Machine is not on the network */ |
#define ENOPKG 65 /* Package not installed */ |
#define EREMOTE 66 /* Object is remote */ |
#define ENOLINK 67 /* Link has been severed */ |
#define EADV 68 /* Advertise error */ |
#define ESRMNT 69 /* Srmount error */ |
#define ECOMM 70 /* Communication error on send */ |
#define EPROTO 71 /* Protocol error */ |
#define EMULTIHOP 72 /* Multihop attempted */ |
#define EDOTDOT 73 /* RFS specific error */ |
#define EBADMSG 74 /* Not a data message */ |
#define EOVERFLOW 75 /* Value too large for defined data type */ |
#define ENOTUNIQ 76 /* Name not unique on network */ |
#define EBADFD 77 /* File descriptor in bad state */ |
#define EREMCHG 78 /* Remote address changed */ |
#define ELIBACC 79 /* Can not access a needed shared library */ |
#define ELIBBAD 80 /* Accessing a corrupted shared library */ |
#define ELIBSCN 81 /* .lib section in a.out corrupted */ |
#define ELIBMAX 82 /* Attempting to link in too many shared libraries */ |
#define ELIBEXEC 83 /* Cannot exec a shared library directly */ |
#define EILSEQ 84 /* Illegal byte sequence */ |
#define ERESTART 85 /* Interrupted system call should be restarted */ |
#define ESTRPIPE 86 /* Streams pipe error */ |
#define EUSERS 87 /* Too many users */ |
#define ENOTSOCK 88 /* Socket operation on non-socket */ |
#define EDESTADDRREQ 89 /* Destination address required */ |
#define EMSGSIZE 90 /* Message too long */ |
#define EPROTOTYPE 91 /* Protocol wrong type for socket */ |
#define ENOPROTOOPT 92 /* Protocol not available */ |
#define EPROTONOSUPPORT 93 /* Protocol not supported */ |
#define ESOCKTNOSUPPORT 94 /* Socket type not supported */ |
#define EOPNOTSUPP 95 /* Operation not supported on transport endpoint */ |
#define EPFNOSUPPORT 96 /* Protocol family not supported */ |
#define EAFNOSUPPORT 97 /* Address family not supported by protocol */ |
#define EADDRINUSE 98 /* Address already in use */ |
#define EADDRNOTAVAIL 99 /* Cannot assign requested address */ |
#define ENETDOWN 100 /* Network is down */ |
#define ENETUNREACH 101 /* Network is unreachable */ |
#define ENETRESET 102 /* Network dropped connection because of reset */ |
#define ECONNABORTED 103 /* Software caused connection abort */ |
#define ECONNRESET 104 /* Connection reset by peer */ |
#define ENOBUFS 105 /* No buffer space available */ |
#define EISCONN 106 /* Transport endpoint is already connected */ |
#define ENOTCONN 107 /* Transport endpoint is not connected */ |
#define ESHUTDOWN 108 /* Cannot send after transport endpoint shutdown */ |
#define ETOOMANYREFS 109 /* Too many references: cannot splice */ |
#define ETIMEDOUT 110 /* Connection timed out */ |
#define ECONNREFUSED 111 /* Connection refused */ |
#define EHOSTDOWN 112 /* Host is down */ |
#define EHOSTUNREACH 113 /* No route to host */ |
#define EALREADY 114 /* Operation already in progress */ |
#define EINPROGRESS 115 /* Operation now in progress */ |
#define ESTALE 116 /* Stale NFS file handle */ |
#define EUCLEAN 117 /* Structure needs cleaning */ |
#define ENOTNAM 118 /* Not a XENIX named type file */ |
#define ENAVAIL 119 /* No XENIX semaphores available */ |
#define EISNAM 120 /* Is a named type file */ |
#define EREMOTEIO 121 /* Remote I/O error */ |
#define EDQUOT 122 /* Quota exceeded */ |
#define ENOMEDIUM 123 /* No medium found */ |
#define EMEDIUMTYPE 124 /* Wrong medium type */ |
#define ECANCELED 125 /* Operation Canceled */ |
#define ENOKEY 126 /* Required key not available */ |
#define EKEYEXPIRED 127 /* Key has expired */ |
#define EKEYREVOKED 128 /* Key has been revoked */ |
#define EKEYREJECTED 129 /* Key was rejected by service */ |
/* for robust mutexes */ |
#define EOWNERDEAD 130 /* Owner died */ |
#define ENOTRECOVERABLE 131 /* State not recoverable */ |
#define ERFKILL 132 /* Operation not possible due to RF-kill */ |
#endif |
/drivers/video/drm/includes/pci.h |
---|
0,0 → 1,566 |
#include <types.h> |
#include <list.h> |
#ifndef __PCI_H__ |
#define __PCI_H__ |
#define PCI_ANY_ID (~0) |
#define PCI_CLASS_NOT_DEFINED 0x0000 |
#define PCI_CLASS_NOT_DEFINED_VGA 0x0001 |
#define PCI_BASE_CLASS_STORAGE 0x01 |
#define PCI_CLASS_STORAGE_SCSI 0x0100 |
#define PCI_CLASS_STORAGE_IDE 0x0101 |
#define PCI_CLASS_STORAGE_FLOPPY 0x0102 |
#define PCI_CLASS_STORAGE_IPI 0x0103 |
#define PCI_CLASS_STORAGE_RAID 0x0104 |
#define PCI_CLASS_STORAGE_SATA 0x0106 |
#define PCI_CLASS_STORAGE_SATA_AHCI 0x010601 |
#define PCI_CLASS_STORAGE_SAS 0x0107 |
#define PCI_CLASS_STORAGE_OTHER 0x0180 |
#define PCI_BASE_CLASS_NETWORK 0x02 |
#define PCI_CLASS_NETWORK_ETHERNET 0x0200 |
#define PCI_CLASS_NETWORK_TOKEN_RING 0x0201 |
#define PCI_CLASS_NETWORK_FDDI 0x0202 |
#define PCI_CLASS_NETWORK_ATM 0x0203 |
#define PCI_CLASS_NETWORK_OTHER 0x0280 |
#define PCI_BASE_CLASS_DISPLAY 0x03 |
#define PCI_CLASS_DISPLAY_VGA 0x0300 |
#define PCI_CLASS_DISPLAY_XGA 0x0301 |
#define PCI_CLASS_DISPLAY_3D 0x0302 |
#define PCI_CLASS_DISPLAY_OTHER 0x0380 |
#define PCI_BASE_CLASS_MULTIMEDIA 0x04 |
#define PCI_CLASS_MULTIMEDIA_VIDEO 0x0400 |
#define PCI_CLASS_MULTIMEDIA_AUDIO 0x0401 |
#define PCI_CLASS_MULTIMEDIA_PHONE 0x0402 |
#define PCI_CLASS_MULTIMEDIA_OTHER 0x0480 |
#define PCI_BASE_CLASS_MEMORY 0x05 |
#define PCI_CLASS_MEMORY_RAM 0x0500 |
#define PCI_CLASS_MEMORY_FLASH 0x0501 |
#define PCI_CLASS_MEMORY_OTHER 0x0580 |
#define PCI_BASE_CLASS_BRIDGE 0x06 |
#define PCI_CLASS_BRIDGE_HOST 0x0600 |
#define PCI_CLASS_BRIDGE_ISA 0x0601 |
#define PCI_CLASS_BRIDGE_EISA 0x0602 |
#define PCI_CLASS_BRIDGE_MC 0x0603 |
#define PCI_CLASS_BRIDGE_PCI 0x0604 |
#define PCI_CLASS_BRIDGE_PCMCIA 0x0605 |
#define PCI_CLASS_BRIDGE_NUBUS 0x0606 |
#define PCI_CLASS_BRIDGE_CARDBUS 0x0607 |
#define PCI_CLASS_BRIDGE_RACEWAY 0x0608 |
#define PCI_CLASS_BRIDGE_OTHER 0x0680 |
#define PCI_BASE_CLASS_COMMUNICATION 0x07 |
#define PCI_CLASS_COMMUNICATION_SERIAL 0x0700 |
#define PCI_CLASS_COMMUNICATION_PARALLEL 0x0701 |
#define PCI_CLASS_COMMUNICATION_MULTISERIAL 0x0702 |
#define PCI_CLASS_COMMUNICATION_MODEM 0x0703 |
#define PCI_CLASS_COMMUNICATION_OTHER 0x0780 |
#define PCI_BASE_CLASS_SYSTEM 0x08 |
#define PCI_CLASS_SYSTEM_PIC 0x0800 |
#define PCI_CLASS_SYSTEM_PIC_IOAPIC 0x080010 |
#define PCI_CLASS_SYSTEM_PIC_IOXAPIC 0x080020 |
#define PCI_CLASS_SYSTEM_DMA 0x0801 |
#define PCI_CLASS_SYSTEM_TIMER 0x0802 |
#define PCI_CLASS_SYSTEM_RTC 0x0803 |
#define PCI_CLASS_SYSTEM_PCI_HOTPLUG 0x0804 |
#define PCI_CLASS_SYSTEM_SDHCI 0x0805 |
#define PCI_CLASS_SYSTEM_OTHER 0x0880 |
#define PCI_BASE_CLASS_INPUT 0x09 |
#define PCI_CLASS_INPUT_KEYBOARD 0x0900 |
#define PCI_CLASS_INPUT_PEN 0x0901 |
#define PCI_CLASS_INPUT_MOUSE 0x0902 |
#define PCI_CLASS_INPUT_SCANNER 0x0903 |
#define PCI_CLASS_INPUT_GAMEPORT 0x0904 |
#define PCI_CLASS_INPUT_OTHER 0x0980 |
#define PCI_BASE_CLASS_DOCKING 0x0a |
#define PCI_CLASS_DOCKING_GENERIC 0x0a00 |
#define PCI_CLASS_DOCKING_OTHER 0x0a80 |
#define PCI_BASE_CLASS_PROCESSOR 0x0b |
#define PCI_CLASS_PROCESSOR_386 0x0b00 |
#define PCI_CLASS_PROCESSOR_486 0x0b01 |
#define PCI_CLASS_PROCESSOR_PENTIUM 0x0b02 |
#define PCI_CLASS_PROCESSOR_ALPHA 0x0b10 |
#define PCI_CLASS_PROCESSOR_POWERPC 0x0b20 |
#define PCI_CLASS_PROCESSOR_MIPS 0x0b30 |
#define PCI_CLASS_PROCESSOR_CO 0x0b40 |
#define PCI_BASE_CLASS_SERIAL 0x0c |
#define PCI_CLASS_SERIAL_FIREWIRE 0x0c00 |
#define PCI_CLASS_SERIAL_FIREWIRE_OHCI 0x0c0010 |
#define PCI_CLASS_SERIAL_ACCESS 0x0c01 |
#define PCI_CLASS_SERIAL_SSA 0x0c02 |
#define PCI_CLASS_SERIAL_USB 0x0c03 |
#define PCI_CLASS_SERIAL_USB_UHCI 0x0c0300 |
#define PCI_CLASS_SERIAL_USB_OHCI 0x0c0310 |
#define PCI_CLASS_SERIAL_USB_EHCI 0x0c0320 |
#define PCI_CLASS_SERIAL_FIBER 0x0c04 |
#define PCI_CLASS_SERIAL_SMBUS 0x0c05 |
#define PCI_BASE_CLASS_WIRELESS 0x0d |
#define PCI_CLASS_WIRELESS_RF_CONTROLLER 0x0d10 |
#define PCI_CLASS_WIRELESS_WHCI 0x0d1010 |
#define PCI_BASE_CLASS_INTELLIGENT 0x0e |
#define PCI_CLASS_INTELLIGENT_I2O 0x0e00 |
#define PCI_BASE_CLASS_SATELLITE 0x0f |
#define PCI_CLASS_SATELLITE_TV 0x0f00 |
#define PCI_CLASS_SATELLITE_AUDIO 0x0f01 |
#define PCI_CLASS_SATELLITE_VOICE 0x0f03 |
#define PCI_CLASS_SATELLITE_DATA 0x0f04 |
#define PCI_BASE_CLASS_CRYPT 0x10 |
#define PCI_CLASS_CRYPT_NETWORK 0x1000 |
#define PCI_CLASS_CRYPT_ENTERTAINMENT 0x1001 |
#define PCI_CLASS_CRYPT_OTHER 0x1080 |
#define PCI_BASE_CLASS_SIGNAL_PROCESSING 0x11 |
#define PCI_CLASS_SP_DPIO 0x1100 |
#define PCI_CLASS_SP_OTHER 0x1180 |
#define PCI_CLASS_OTHERS 0xff |
/* |
* Under PCI, each device has 256 bytes of configuration address space, |
* of which the first 64 bytes are standardized as follows: |
*/ |
#define PCI_VENDOR_ID 0x000 /* 16 bits */ |
#define PCI_DEVICE_ID 0x002 /* 16 bits */ |
#define PCI_COMMAND 0x004 /* 16 bits */ |
#define PCI_COMMAND_IO 0x001 /* Enable response in I/O space */ |
#define PCI_COMMAND_MEMORY 0x002 /* Enable response in Memory space */ |
#define PCI_COMMAND_MASTER 0x004 /* Enable bus mastering */ |
#define PCI_COMMAND_SPECIAL 0x008 /* Enable response to special cycles */ |
#define PCI_COMMAND_INVALIDATE 0x010 /* Use memory write and invalidate */ |
#define PCI_COMMAND_VGA_PALETTE 0x020 /* Enable palette snooping */ |
#define PCI_COMMAND_PARITY 0x040 /* Enable parity checking */ |
#define PCI_COMMAND_WAIT 0x080 /* Enable address/data stepping */ |
#define PCI_COMMAND_SERR 0x100 /* Enable SERR */ |
#define PCI_COMMAND_FAST_BACK 0x200 /* Enable back-to-back writes */ |
#define PCI_COMMAND_INTX_DISABLE 0x400 /* INTx Emulation Disable */ |
#define PCI_STATUS 0x006 /* 16 bits */ |
#define PCI_STATUS_CAP_LIST 0x010 /* Support Capability List */ |
#define PCI_STATUS_66MHZ 0x020 /* Support 66 Mhz PCI 2.1 bus */ |
#define PCI_STATUS_UDF 0x040 /* Support User Definable Features [obsolete] */ |
#define PCI_STATUS_FAST_BACK 0x080 /* Accept fast-back to back */ |
#define PCI_STATUS_PARITY 0x100 /* Detected parity error */ |
#define PCI_STATUS_DEVSEL_MASK 0x600 /* DEVSEL timing */ |
#define PCI_STATUS_DEVSEL_FAST 0x000 |
#define PCI_STATUS_DEVSEL_MEDIUM 0x200 |
#define PCI_STATUS_DEVSEL_SLOW 0x400 |
#define PCI_STATUS_SIG_TARGET_ABORT 0x800 /* Set on target abort */ |
#define PCI_STATUS_REC_TARGET_ABORT 0x1000 /* Master ack of " */ |
#define PCI_STATUS_REC_MASTER_ABORT 0x2000 /* Set on master abort */ |
#define PCI_STATUS_SIG_SYSTEM_ERROR 0x4000 /* Set when we drive SERR */ |
#define PCI_STATUS_DETECTED_PARITY 0x8000 /* Set on parity error */ |
#define PCI_CLASS_REVISION 0x08 /* High 24 bits are class, low 8 revision */ |
#define PCI_REVISION_ID 0x08 /* Revision ID */ |
#define PCI_CLASS_PROG 0x09 /* Reg. Level Programming Interface */ |
#define PCI_CLASS_DEVICE 0x0a /* Device class */ |
#define PCI_CACHE_LINE_SIZE 0x0c /* 8 bits */ |
#define PCI_LATENCY_TIMER 0x0d /* 8 bits */ |
#define PCI_HEADER_TYPE 0x0e /* 8 bits */ |
#define PCI_HEADER_TYPE_NORMAL 0 |
#define PCI_HEADER_TYPE_BRIDGE 1 |
#define PCI_HEADER_TYPE_CARDBUS 2 |
#define PCI_BIST 0x0f /* 8 bits */ |
#define PCI_BIST_CODE_MASK 0x0f /* Return result */ |
#define PCI_BIST_START 0x40 /* 1 to start BIST, 2 secs or less */ |
#define PCI_BIST_CAPABLE 0x80 /* 1 if BIST capable */ |
/* |
* Base addresses specify locations in memory or I/O space. |
* Decoded size can be determined by writing a value of |
* 0xffffffff to the register, and reading it back. Only |
* 1 bits are decoded. |
*/ |
#define PCI_BASE_ADDRESS_0 0x10 /* 32 bits */ |
#define PCI_BASE_ADDRESS_1 0x14 /* 32 bits [htype 0,1 only] */ |
#define PCI_BASE_ADDRESS_2 0x18 /* 32 bits [htype 0 only] */ |
#define PCI_BASE_ADDRESS_3 0x1c /* 32 bits */ |
#define PCI_BASE_ADDRESS_4 0x20 /* 32 bits */ |
#define PCI_BASE_ADDRESS_5 0x24 /* 32 bits */ |
#define PCI_BASE_ADDRESS_SPACE 0x01 /* 0 = memory, 1 = I/O */ |
#define PCI_BASE_ADDRESS_SPACE_IO 0x01 |
#define PCI_BASE_ADDRESS_SPACE_MEMORY 0x00 |
#define PCI_BASE_ADDRESS_MEM_TYPE_MASK 0x06 |
#define PCI_BASE_ADDRESS_MEM_TYPE_32 0x00 /* 32 bit address */ |
#define PCI_BASE_ADDRESS_MEM_TYPE_1M 0x02 /* Below 1M [obsolete] */ |
#define PCI_BASE_ADDRESS_MEM_TYPE_64 0x04 /* 64 bit address */ |
#define PCI_BASE_ADDRESS_MEM_PREFETCH 0x08 /* prefetchable? */ |
#define PCI_BASE_ADDRESS_MEM_MASK (~0x0fUL) |
#define PCI_BASE_ADDRESS_IO_MASK (~0x03UL) |
/* bit 1 is reserved if address_space = 1 */ |
#define PCI_ROM_ADDRESS1 0x38 /* Same as PCI_ROM_ADDRESS, but for htype 1 */ |
/* Header type 0 (normal devices) */ |
#define PCI_CARDBUS_CIS 0x28 |
#define PCI_SUBSYSTEM_VENDOR_ID 0x2c |
#define PCI_SUBSYSTEM_ID 0x2e |
#define PCI_ROM_ADDRESS 0x30 /* Bits 31..11 are address, 10..1 reserved */ |
#define PCI_ROM_ADDRESS_ENABLE 0x01 |
#define PCI_ROM_ADDRESS_MASK (~0x7ffUL) |
#define PCI_INTERRUPT_LINE 0x3c /* 8 bits */ |
#define PCI_INTERRUPT_PIN 0x3d /* 8 bits */ |
#define PCI_CB_SUBSYSTEM_VENDOR_ID 0x40 |
#define PCI_CB_SUBSYSTEM_ID 0x42 |
#define PCI_CAPABILITY_LIST 0x34 /* Offset of first capability list entry */ |
#define PCI_CB_CAPABILITY_LIST 0x14 |
/* Capability lists */ |
#define PCI_CAP_LIST_ID 0 /* Capability ID */ |
#define PCI_CAP_ID_PM 0x01 /* Power Management */ |
#define PCI_CAP_ID_AGP 0x02 /* Accelerated Graphics Port */ |
#define PCI_CAP_ID_VPD 0x03 /* Vital Product Data */ |
#define PCI_CAP_ID_SLOTID 0x04 /* Slot Identification */ |
#define PCI_CAP_ID_MSI 0x05 /* Message Signalled Interrupts */ |
#define PCI_CAP_ID_CHSWP 0x06 /* CompactPCI HotSwap */ |
#define PCI_CAP_ID_PCIX 0x07 /* PCI-X */ |
#define PCI_CAP_ID_HT 0x08 /* HyperTransport */ |
#define PCI_CAP_ID_VNDR 0x09 /* Vendor specific capability */ |
#define PCI_CAP_ID_SHPC 0x0C /* PCI Standard Hot-Plug Controller */ |
#define PCI_CAP_ID_EXP 0x10 /* PCI Express */ |
#define PCI_CAP_ID_MSIX 0x11 /* MSI-X */ |
#define PCI_CAP_LIST_NEXT 1 /* Next capability in the list */ |
#define PCI_CAP_FLAGS 2 /* Capability defined flags (16 bits) */ |
#define PCI_CAP_SIZEOF 4 |
/* AGP registers */ |
#define PCI_AGP_VERSION 2 /* BCD version number */ |
#define PCI_AGP_RFU 3 /* Rest of capability flags */ |
#define PCI_AGP_STATUS 4 /* Status register */ |
#define PCI_AGP_STATUS_RQ_MASK 0xff000000 /* Maximum number of requests - 1 */ |
#define PCI_AGP_STATUS_SBA 0x0200 /* Sideband addressing supported */ |
#define PCI_AGP_STATUS_64BIT 0x0020 /* 64-bit addressing supported */ |
#define PCI_AGP_STATUS_FW 0x0010 /* FW transfers supported */ |
#define PCI_AGP_STATUS_RATE4 0x0004 /* 4x transfer rate supported */ |
#define PCI_AGP_STATUS_RATE2 0x0002 /* 2x transfer rate supported */ |
#define PCI_AGP_STATUS_RATE1 0x0001 /* 1x transfer rate supported */ |
#define PCI_AGP_COMMAND 8 /* Control register */ |
#define PCI_AGP_COMMAND_RQ_MASK 0xff000000 /* Master: Maximum number of requests */ |
#define PCI_AGP_COMMAND_SBA 0x0200 /* Sideband addressing enabled */ |
#define PCI_AGP_COMMAND_AGP 0x0100 /* Allow processing of AGP transactions */ |
#define PCI_AGP_COMMAND_64BIT 0x0020 /* Allow processing of 64-bit addresses */ |
#define PCI_AGP_COMMAND_FW 0x0010 /* Force FW transfers */ |
#define PCI_AGP_COMMAND_RATE4 0x0004 /* Use 4x rate */ |
#define PCI_AGP_COMMAND_RATE2 0x0002 /* Use 2x rate */ |
#define PCI_AGP_COMMAND_RATE1 0x0001 /* Use 1x rate */ |
#define PCI_AGP_SIZEOF 12 |
#define PCI_MAP_REG_START 0x10 |
#define PCI_MAP_REG_END 0x28 |
#define PCI_MAP_ROM_REG 0x30 |
#define PCI_MAP_MEMORY 0x00000000 |
#define PCI_MAP_IO 0x00000001 |
#define PCI_MAP_MEMORY_TYPE 0x00000007 |
#define PCI_MAP_IO_TYPE 0x00000003 |
#define PCI_MAP_MEMORY_TYPE_32BIT 0x00000000 |
#define PCI_MAP_MEMORY_TYPE_32BIT_1M 0x00000002 |
#define PCI_MAP_MEMORY_TYPE_64BIT 0x00000004 |
#define PCI_MAP_MEMORY_TYPE_MASK 0x00000006 |
#define PCI_MAP_MEMORY_CACHABLE 0x00000008 |
#define PCI_MAP_MEMORY_ATTR_MASK 0x0000000e |
#define PCI_MAP_MEMORY_ADDRESS_MASK 0xfffffff0 |
#define PCI_MAP_IO_ATTR_MASK 0x00000003 |
#define PCI_MAP_IS_IO(b) ((b) & PCI_MAP_IO) |
#define PCI_MAP_IS_MEM(b) (!PCI_MAP_IS_IO(b)) |
#define PCI_MAP_IS64BITMEM(b) \ |
(((b) & PCI_MAP_MEMORY_TYPE_MASK) == PCI_MAP_MEMORY_TYPE_64BIT) |
#define PCIGETMEMORY(b) ((b) & PCI_MAP_MEMORY_ADDRESS_MASK) |
#define PCIGETMEMORY64HIGH(b) (*((CARD32*)&b + 1)) |
#define PCIGETMEMORY64(b) \ |
(PCIGETMEMORY(b) | ((CARD64)PCIGETMEMORY64HIGH(b) << 32)) |
#define PCI_MAP_IO_ADDRESS_MASK 0xfffffffc |
#define PCIGETIO(b) ((b) & PCI_MAP_IO_ADDRESS_MASK) |
#define PCI_MAP_ROM_DECODE_ENABLE 0x00000001 |
#define PCI_MAP_ROM_ADDRESS_MASK 0xfffff800 |
#define PCIGETROM(b) ((b) & PCI_MAP_ROM_ADDRESS_MASK) |
#ifndef PCI_DOM_MASK |
# define PCI_DOM_MASK 0x0ffu |
#endif |
#define PCI_DOMBUS_MASK (((PCI_DOM_MASK) << 8) | 0x0ffu) |
#define PCI_MAKE_TAG(b,d,f) ((((b) & (PCI_DOMBUS_MASK)) << 16) | \ |
(((d) & 0x00001fu) << 11) | \ |
(((f) & 0x000007u) << 8)) |
#define PCI_BUS_FROM_TAG(tag) (((tag) >> 16) & (PCI_DOMBUS_MASK)) |
#define PCI_DEV_FROM_TAG(tag) (((tag) & 0x0000f800u) >> 11) |
#define PCI_FUNC_FROM_TAG(tag) (((tag) & 0x00000700u) >> 8) |
#define PCI_DFN_FROM_TAG(tag) (((tag) & 0x0000ff00u) >> 8) |
#define PCI_DEVFN(slot, func) ((((slot) & 0x1f) << 3) | ((func) & 0x07)) |
#define PCI_SLOT(devfn) (((devfn) >> 3) & 0x1f) |
#define PCI_FUNC(devfn) ((devfn) & 0x07) |
typedef unsigned int PCITAG; |
extern inline PCITAG |
pciTag(int busnum, int devnum, int funcnum) |
{ |
return(PCI_MAKE_TAG(busnum,devnum,funcnum)); |
} |
struct resource |
{ |
resource_size_t start; |
resource_size_t end; |
// const char *name; |
unsigned long flags; |
// struct resource *parent, *sibling, *child; |
}; |
/* |
* IO resources have these defined flags. |
*/ |
#define IORESOURCE_BITS 0x000000ff /* Bus-specific bits */ |
#define IORESOURCE_IO 0x00000100 /* Resource type */ |
#define IORESOURCE_MEM 0x00000200 |
#define IORESOURCE_IRQ 0x00000400 |
#define IORESOURCE_DMA 0x00000800 |
#define IORESOURCE_PREFETCH 0x00001000 /* No side effects */ |
#define IORESOURCE_READONLY 0x00002000 |
#define IORESOURCE_CACHEABLE 0x00004000 |
#define IORESOURCE_RANGELENGTH 0x00008000 |
#define IORESOURCE_SHADOWABLE 0x00010000 |
#define IORESOURCE_BUS_HAS_VGA 0x00080000 |
#define IORESOURCE_DISABLED 0x10000000 |
#define IORESOURCE_UNSET 0x20000000 |
#define IORESOURCE_AUTO 0x40000000 |
#define IORESOURCE_BUSY 0x80000000 /* Driver has marked this resource busy */ |
/* ISA PnP IRQ specific bits (IORESOURCE_BITS) */ |
#define IORESOURCE_IRQ_HIGHEDGE (1<<0) |
#define IORESOURCE_IRQ_LOWEDGE (1<<1) |
#define IORESOURCE_IRQ_HIGHLEVEL (1<<2) |
#define IORESOURCE_IRQ_LOWLEVEL (1<<3) |
#define IORESOURCE_IRQ_SHAREABLE (1<<4) |
/* ISA PnP DMA specific bits (IORESOURCE_BITS) */ |
#define IORESOURCE_DMA_TYPE_MASK (3<<0) |
#define IORESOURCE_DMA_8BIT (0<<0) |
#define IORESOURCE_DMA_8AND16BIT (1<<0) |
#define IORESOURCE_DMA_16BIT (2<<0) |
#define IORESOURCE_DMA_MASTER (1<<2) |
#define IORESOURCE_DMA_BYTE (1<<3) |
#define IORESOURCE_DMA_WORD (1<<4) |
#define IORESOURCE_DMA_SPEED_MASK (3<<6) |
#define IORESOURCE_DMA_COMPATIBLE (0<<6) |
#define IORESOURCE_DMA_TYPEA (1<<6) |
#define IORESOURCE_DMA_TYPEB (2<<6) |
#define IORESOURCE_DMA_TYPEF (3<<6) |
/* ISA PnP memory I/O specific bits (IORESOURCE_BITS) */ |
#define IORESOURCE_MEM_WRITEABLE (1<<0) /* dup: IORESOURCE_READONLY */ |
#define IORESOURCE_MEM_CACHEABLE (1<<1) /* dup: IORESOURCE_CACHEABLE */ |
#define IORESOURCE_MEM_RANGELENGTH (1<<2) /* dup: IORESOURCE_RANGELENGTH */ |
#define IORESOURCE_MEM_TYPE_MASK (3<<3) |
#define IORESOURCE_MEM_8BIT (0<<3) |
#define IORESOURCE_MEM_16BIT (1<<3) |
#define IORESOURCE_MEM_8AND16BIT (2<<3) |
#define IORESOURCE_MEM_32BIT (3<<3) |
#define IORESOURCE_MEM_SHADOWABLE (1<<5) /* dup: IORESOURCE_SHADOWABLE */ |
#define IORESOURCE_MEM_EXPANSIONROM (1<<6) |
/* PCI ROM control bits (IORESOURCE_BITS) */ |
#define IORESOURCE_ROM_ENABLE (1<<0) /* ROM is enabled, same as PCI_ROM_ADDRESS_ENABLE */ |
#define IORESOURCE_ROM_SHADOW (1<<1) /* ROM is copy at C000:0 */ |
#define IORESOURCE_ROM_COPY (1<<2) /* ROM is alloc'd copy, resource field overlaid */ |
#define IORESOURCE_ROM_BIOS_COPY (1<<3) /* ROM is BIOS copy, resource field overlaid */ |
/* PCI control bits. Shares IORESOURCE_BITS with above PCI ROM. */ |
#define IORESOURCE_PCI_FIXED (1<<4) /* Do not move resource */ |
/* |
* For PCI devices, the region numbers are assigned this way: |
* |
* 0-5 standard PCI regions |
* 6 expansion ROM |
* 7-10 bridges: address space assigned to buses behind the bridge |
*/ |
#define PCI_ROM_RESOURCE 6 |
#define PCI_BRIDGE_RESOURCES 7 |
#define PCI_NUM_RESOURCES 11 |
#ifndef PCI_BUS_NUM_RESOURCES |
#define PCI_BUS_NUM_RESOURCES 8 |
#endif |
#define DEVICE_COUNT_RESOURCE 12 |
/* |
* The pci_dev structure is used to describe PCI devices. |
*/ |
struct pci_dev { |
// struct list_head bus_list; /* node in per-bus list */ |
// struct pci_bus *bus; /* bus this device is on */ |
// struct pci_bus *subordinate; /* bus this device bridges to */ |
// void *sysdata; /* hook for sys-specific extension */ |
// struct proc_dir_entry *procent; /* device entry in /proc/bus/pci */ |
// struct pci_slot *slot; /* Physical slot this device is in */ |
u32_t bus; |
u32_t devfn; /* encoded device & function index */ |
u16_t vendor; |
u16_t device; |
u16_t subsystem_vendor; |
u16_t subsystem_device; |
u32_t class; /* 3 bytes: (base,sub,prog-if) */ |
uint8_t revision; /* PCI revision, low byte of class word */ |
uint8_t hdr_type; /* PCI header type (`multi' flag masked out) */ |
uint8_t pcie_type; /* PCI-E device/port type */ |
uint8_t rom_base_reg; /* which config register controls the ROM */ |
uint8_t pin; /* which interrupt pin this device uses */ |
// struct pci_driver *driver; /* which driver has allocated this device */ |
uint64_t dma_mask; /* Mask of the bits of bus address this |
device implements. Normally this is |
0xffffffff. You only need to change |
this if your device has broken DMA |
or supports 64-bit transfers. */ |
// struct device_dma_parameters dma_parms; |
// pci_power_t current_state; /* Current operating state. In ACPI-speak, |
// this is D0-D3, D0 being fully functional, |
// and D3 being off. */ |
// int pm_cap; /* PM capability offset in the |
// configuration space */ |
unsigned int pme_support:5; /* Bitmask of states from which PME# |
can be generated */ |
unsigned int d1_support:1; /* Low power state D1 is supported */ |
unsigned int d2_support:1; /* Low power state D2 is supported */ |
unsigned int no_d1d2:1; /* Only allow D0 and D3 */ |
// pci_channel_state_t error_state; /* current connectivity state */ |
// struct device dev; /* Generic device interface */ |
// int cfg_size; /* Size of configuration space */ |
/* |
* Instead of touching interrupt line and base address registers |
* directly, use the values stored here. They might be different! |
*/ |
unsigned int irq; |
struct resource resource[DEVICE_COUNT_RESOURCE]; /* I/O and memory regions + expansion ROMs */ |
/* These fields are used by common fixups */ |
unsigned int transparent:1; /* Transparent PCI bridge */ |
unsigned int multifunction:1;/* Part of multi-function device */ |
/* keep track of device state */ |
unsigned int is_added:1; |
unsigned int is_busmaster:1; /* device is busmaster */ |
unsigned int no_msi:1; /* device may not use msi */ |
unsigned int block_ucfg_access:1; /* userspace config space access is blocked */ |
unsigned int broken_parity_status:1; /* Device generates false positive parity */ |
unsigned int irq_reroute_variant:2; /* device needs IRQ rerouting variant */ |
unsigned int msi_enabled:1; |
unsigned int msix_enabled:1; |
unsigned int ari_enabled:1; /* ARI forwarding */ |
unsigned int is_managed:1; |
unsigned int is_pcie:1; |
unsigned int state_saved:1; |
unsigned int is_physfn:1; |
unsigned int is_virtfn:1; |
// pci_dev_flags_t dev_flags; |
// atomic_t enable_cnt; /* pci_enable_device has been called */ |
// u32 saved_config_space[16]; /* config space saved at suspend time */ |
// struct hlist_head saved_cap_space; |
// struct bin_attribute *rom_attr; /* attribute descriptor for sysfs ROM entry */ |
// int rom_attr_enabled; /* has display of the rom attribute been enabled? */ |
// struct bin_attribute *res_attr[DEVICE_COUNT_RESOURCE]; /* sysfs file for resources */ |
// struct bin_attribute *res_attr_wc[DEVICE_COUNT_RESOURCE]; /* sysfs file for WC mapping of resources */ |
}; |
#define pci_resource_start(dev, bar) ((dev)->resource[(bar)].start) |
#define pci_resource_end(dev, bar) ((dev)->resource[(bar)].end) |
#define pci_resource_flags(dev, bar) ((dev)->resource[(bar)].flags) |
#define pci_resource_len(dev,bar) \ |
((pci_resource_start((dev), (bar)) == 0 && \ |
pci_resource_end((dev), (bar)) == \ |
pci_resource_start((dev), (bar))) ? 0 : \ |
\ |
(pci_resource_end((dev), (bar)) - \ |
pci_resource_start((dev), (bar)) + 1)) |
struct pci_device_id |
{ |
u16_t vendor, device; /* Vendor and device ID or PCI_ANY_ID*/ |
u16_t subvendor, subdevice; /* Subsystem ID's or PCI_ANY_ID */ |
u32_t class, class_mask; /* (class,subclass,prog-if) triplet */ |
u32_t driver_data; /* Data private to the driver */ |
}; |
typedef struct |
{ |
struct list_head link; |
struct pci_dev pci_dev; |
}dev_t; |
int enum_pci_devices(void); |
struct pci_device_id* |
find_pci_device(dev_t* pdev, struct pci_device_id *idlist); |
#define DMA_BIT_MASK(n) (((n) == 64) ? ~0ULL : ((1ULL<<(n))-1)) |
int pci_set_dma_mask(struct pci_dev *dev, u64 mask); |
#define pci_name(x) "radeon" |
#endif //__PCI__H__ |
/drivers/video/drm/radeon/radeon_object_kos.c |
---|
File deleted |
/drivers/video/drm/radeon/radeon_ttm.c |
---|
File deleted |
/drivers/video/drm/radeon/atombios_dp.c |
---|
332,13 → 332,11 |
PROCESS_AUX_CHANNEL_TRANSACTION_PS_ALLOCATION args; |
int index = GetIndexIntoMasterTable(COMMAND, ProcessAuxChannelTransaction); |
unsigned char *base; |
int retry_count = 0; |
memset(&args, 0, sizeof(args)); |
base = (unsigned char *)rdev->mode_info.atom_context->scratch; |
retry: |
memcpy(base, req_bytes, num_bytes); |
args.lpAuxRequest = 0; |
349,12 → 347,10 |
atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); |
if (args.ucReplyStatus && !args.ucDataOutLen) { |
if (args.ucReplyStatus == 0x20 && retry_count < 10) |
goto retry; |
DRM_DEBUG("failed to get auxch %02x%02x %02x %02x 0x%02x %02x after %d retries\n", |
if (args.ucReplyStatus) { |
DRM_DEBUG("failed to get auxch %02x%02x %02x %02x 0x%02x %02x\n", |
req_bytes[1], req_bytes[0], req_bytes[2], req_bytes[3], |
chan->rec.i2c_id, args.ucReplyStatus, retry_count); |
chan->rec.i2c_id, args.ucReplyStatus); |
return false; |
} |
/drivers/video/drm/radeon/pci.c |
---|
345,7 → 345,7 |
hdr = PciRead8(bus, devfn, PCI_HEADER_TYPE); |
dev = (pci_dev_t*)kzalloc(sizeof(pci_dev_t), 0); |
dev = (pci_dev_t*)kzalloc(sizeof(dev_t), 0); |
INIT_LIST_HEAD(&dev->link); |
407,7 → 407,7 |
void pci_scan_bus(u32_t bus) |
{ |
u32_t devfn; |
pci_dev_t *dev; |
dev_t *dev; |
for (devfn = 0; devfn < 0x100; devfn += 8) |
/drivers/video/drm/radeon/r100.c |
---|
272,17 → 272,11 |
return RREG32(RADEON_CRTC2_CRNT_FRAME); |
} |
/* Who ever call radeon_fence_emit should call ring_lock and ask |
* for enough space (today caller are ib schedule and buffer move) */ |
void r100_fence_ring_emit(struct radeon_device *rdev, |
struct radeon_fence *fence) |
{ |
/* We have to make sure that caches are flushed before |
* CPU might read something from VRAM. */ |
radeon_ring_write(rdev, PACKET0(RADEON_RB3D_DSTCACHE_CTLSTAT, 0)); |
radeon_ring_write(rdev, RADEON_RB3D_DC_FLUSH_ALL); |
radeon_ring_write(rdev, PACKET0(RADEON_RB3D_ZCACHE_CTLSTAT, 0)); |
radeon_ring_write(rdev, RADEON_RB3D_ZC_FLUSH_ALL); |
/* Who ever call radeon_fence_emit should call ring_lock and ask |
* for enough space (today caller are ib schedule and buffer move) */ |
/* Wait until IDLE & CLEAN */ |
radeon_ring_write(rdev, PACKET0(0x1720, 0)); |
radeon_ring_write(rdev, (1 << 16) | (1 << 17)); |
349,15 → 343,9 |
r100_wb_disable(rdev); |
if (rdev->wb.wb_obj) { |
r = radeon_bo_reserve(rdev->wb.wb_obj, false); |
if (unlikely(r != 0)) { |
dev_err(rdev->dev, "(%d) can't finish WB\n", r); |
return; |
} |
radeon_bo_kunmap(rdev->wb.wb_obj); |
radeon_bo_unpin(rdev->wb.wb_obj); |
radeon_bo_unreserve(rdev->wb.wb_obj); |
radeon_bo_unref(&rdev->wb.wb_obj); |
// radeon_object_kunmap(rdev->wb.wb_obj); |
// radeon_object_unpin(rdev->wb.wb_obj); |
// radeon_object_unref(&rdev->wb.wb_obj); |
rdev->wb.wb = NULL; |
rdev->wb.wb_obj = NULL; |
} |
544,6 → 532,7 |
return err; |
} |
static void r100_cp_load_microcode(struct radeon_device *rdev) |
{ |
const __be32 *fw_data; |
2825,7 → 2814,6 |
} |
/* Enable IRQ */ |
// r100_irq_set(rdev); |
rdev->config.r100.hdp_cntl = RREG32(RADEON_HOST_PATH_CNTL); |
/* 1M ring buffer */ |
// r = r100_cp_init(rdev, 1024 * 1024); |
// if (r) { |
/drivers/video/drm/radeon/r300.c |
---|
152,14 → 152,10 |
tmp |= RADEON_PCIE_TX_GART_UNMAPPED_ACCESS_DISCARD; |
WREG32_PCIE(RADEON_PCIE_TX_GART_CNTL, tmp & ~RADEON_PCIE_TX_GART_EN); |
if (rdev->gart.table.vram.robj) { |
r = radeon_bo_reserve(rdev->gart.table.vram.robj, false); |
if (likely(r == 0)) { |
radeon_bo_kunmap(rdev->gart.table.vram.robj); |
radeon_bo_unpin(rdev->gart.table.vram.robj); |
radeon_bo_unreserve(rdev->gart.table.vram.robj); |
// radeon_object_kunmap(rdev->gart.table.vram.robj); |
// radeon_object_unpin(rdev->gart.table.vram.robj); |
} |
} |
} |
void rv370_pcie_gart_fini(struct radeon_device *rdev) |
{ |
512,14 → 508,11 |
/* DDR for all card after R300 & IGP */ |
rdev->mc.vram_is_ddr = true; |
tmp = RREG32(RADEON_MEM_CNTL); |
tmp &= R300_MEM_NUM_CHANNELS_MASK; |
switch (tmp) { |
case 0: rdev->mc.vram_width = 64; break; |
case 1: rdev->mc.vram_width = 128; break; |
case 2: rdev->mc.vram_width = 256; break; |
default: rdev->mc.vram_width = 128; break; |
if (tmp & R300_MEM_NUM_CHANNELS_MASK) { |
rdev->mc.vram_width = 128; |
} else { |
rdev->mc.vram_width = 64; |
} |
r100_vram_init_sizes(rdev); |
1362,7 → 1355,7 |
// if (r) |
// return r; |
/* Memory manager */ |
r = radeon_bo_init(rdev); |
r = radeon_object_init(rdev); |
if (r) |
return r; |
if (rdev->flags & RADEON_IS_PCIE) { |
1389,7 → 1382,7 |
rv370_pcie_gart_fini(rdev); |
if (rdev->flags & RADEON_IS_PCI) |
r100_pci_gart_fini(rdev); |
// radeon_agp_fini(rdev); |
// radeon_irq_kms_fini(rdev); |
rdev->accel_working = false; |
} |
return 0; |
/drivers/video/drm/radeon/r420.c |
---|
348,7 → 348,7 |
if (r) |
return r; |
} |
r420_set_reg_safe(rdev); |
r300_set_reg_safe(rdev); |
rdev->accel_working = true; |
r = r420_startup(rdev); |
if (r) { |
363,6 → 363,7 |
if (rdev->flags & RADEON_IS_PCI) |
r100_pci_gart_fini(rdev); |
// radeon_agp_fini(rdev); |
// radeon_irq_kms_fini(rdev); |
rdev->accel_working = false; |
} |
return 0; |
/drivers/video/drm/radeon/r600.c |
---|
1711,18 → 1711,3 |
return 0; |
#endif |
} |
/** |
* r600_ioctl_wait_idle - flush host path cache on wait idle ioctl |
* rdev: radeon device structure |
* bo: buffer object struct which userspace is waiting for idle |
* |
* Some R6XX/R7XX doesn't seems to take into account HDP flush performed |
* through ring buffer, this leads to corruption in rendering, see |
* http://bugzilla.kernel.org/show_bug.cgi?id=15186 to avoid this we |
* directly perform HDP flush by writing register through MMIO. |
*/ |
void r600_ioctl_wait_idle(struct radeon_device *rdev, struct radeon_bo *bo) |
{ |
WREG32(R_005480_HDP_MEM_COHERENCY_FLUSH_CNTL, 0x1); |
} |
/drivers/video/drm/radeon/radeon.h |
---|
281,7 → 281,6 |
struct ttm_bo_kmap_obj kmap; |
unsigned pin_count; |
void *kptr; |
u32 cpu_addr; |
u32 tiling_flags; |
u32 pitch; |
int surface_reg; |
288,7 → 287,6 |
/* Constant after initialization */ |
struct radeon_device *rdev; |
struct drm_gem_object *gobj; |
u32 domain; |
}; |
struct radeon_bo_list { |
699,13 → 697,6 |
void (*hpd_fini)(struct radeon_device *rdev); |
bool (*hpd_sense)(struct radeon_device *rdev, enum radeon_hpd_id hpd); |
void (*hpd_set_polarity)(struct radeon_device *rdev, enum radeon_hpd_id hpd); |
/* ioctl hw specific callback. Some hw might want to perform special |
* operation on specific ioctl. For instance on wait idle some hw |
* might want to perform and HDP flush through MMIO as it seems that |
* some R6XX/R7XX hw doesn't take HDP flush into account if programmed |
* through ring. |
*/ |
void (*ioctl_wait_idle)(struct radeon_device *rdev, struct radeon_bo *bo); |
}; |
/* |
1158,7 → 1149,6 |
extern void r600_cp_stop(struct radeon_device *rdev); |
extern void r600_ring_init(struct radeon_device *rdev, unsigned ring_size); |
extern int r600_cp_resume(struct radeon_device *rdev); |
extern void r600_cp_fini(struct radeon_device *rdev); |
extern int r600_count_pipe_bits(uint32_t val); |
extern int r600_gart_clear_page(struct radeon_device *rdev, int i); |
extern int r600_mc_wait_for_idle(struct radeon_device *rdev); |
/drivers/video/drm/radeon/radeon_asic.h |
---|
117,7 → 117,6 |
.hpd_fini = &r100_hpd_fini, |
.hpd_sense = &r100_hpd_sense, |
.hpd_set_polarity = &r100_hpd_set_polarity, |
.ioctl_wait_idle = NULL, |
}; |
177,7 → 176,6 |
.hpd_fini = &r100_hpd_fini, |
.hpd_sense = &r100_hpd_sense, |
.hpd_set_polarity = &r100_hpd_set_polarity, |
.ioctl_wait_idle = NULL, |
}; |
/* |
221,7 → 219,6 |
.hpd_fini = &r100_hpd_fini, |
.hpd_sense = &r100_hpd_sense, |
.hpd_set_polarity = &r100_hpd_set_polarity, |
.ioctl_wait_idle = NULL, |
}; |
270,7 → 267,6 |
.hpd_fini = &r100_hpd_fini, |
.hpd_sense = &r100_hpd_sense, |
.hpd_set_polarity = &r100_hpd_set_polarity, |
.ioctl_wait_idle = NULL, |
}; |
327,7 → 323,6 |
.hpd_fini = &rs600_hpd_fini, |
.hpd_sense = &rs600_hpd_sense, |
.hpd_set_polarity = &rs600_hpd_set_polarity, |
.ioctl_wait_idle = NULL, |
}; |
375,7 → 370,6 |
.hpd_fini = &rs600_hpd_fini, |
.hpd_sense = &rs600_hpd_sense, |
.hpd_set_polarity = &rs600_hpd_set_polarity, |
.ioctl_wait_idle = NULL, |
}; |
427,7 → 421,6 |
.hpd_fini = &rs600_hpd_fini, |
.hpd_sense = &rs600_hpd_sense, |
.hpd_set_polarity = &rs600_hpd_set_polarity, |
.ioctl_wait_idle = NULL, |
}; |
470,7 → 463,6 |
.hpd_fini = &rs600_hpd_fini, |
.hpd_sense = &rs600_hpd_sense, |
.hpd_set_polarity = &rs600_hpd_set_polarity, |
.ioctl_wait_idle = NULL, |
}; |
/* |
512,7 → 504,6 |
bool r600_hpd_sense(struct radeon_device *rdev, enum radeon_hpd_id hpd); |
void r600_hpd_set_polarity(struct radeon_device *rdev, |
enum radeon_hpd_id hpd); |
extern void r600_ioctl_wait_idle(struct radeon_device *rdev, struct radeon_bo *bo); |
static struct radeon_asic r600_asic = { |
.init = &r600_init, |
546,7 → 537,6 |
.hpd_fini = &r600_hpd_fini, |
.hpd_sense = &r600_hpd_sense, |
.hpd_set_polarity = &r600_hpd_set_polarity, |
// .ioctl_wait_idle = r600_ioctl_wait_idle, |
}; |
/* |
590,7 → 580,6 |
.hpd_fini = &r600_hpd_fini, |
.hpd_sense = &r600_hpd_sense, |
.hpd_set_polarity = &r600_hpd_set_polarity, |
// .ioctl_wait_idle = r600_ioctl_wait_idle, |
}; |
#endif |
/drivers/video/drm/radeon/radeon_connectors.c |
---|
580,7 → 580,7 |
struct radeon_connector *radeon_connector = to_radeon_connector(connector); |
struct drm_encoder *encoder; |
struct drm_encoder_helper_funcs *encoder_funcs; |
bool dret = false; |
bool dret; |
enum drm_connector_status ret = connector_status_disconnected; |
encoder = radeon_best_single_encoder(connector); |
587,11 → 587,9 |
if (!encoder) |
ret = connector_status_disconnected; |
if (radeon_connector->ddc_bus) { |
radeon_i2c_do_lock(radeon_connector->ddc_bus, 1); |
dret = radeon_ddc_probe(radeon_connector); |
radeon_i2c_do_lock(radeon_connector->ddc_bus, 0); |
} |
if (dret) { |
if (radeon_connector->edid) { |
kfree(radeon_connector->edid); |
742,13 → 740,11 |
struct drm_mode_object *obj; |
int i; |
enum drm_connector_status ret = connector_status_disconnected; |
bool dret = false; |
bool dret; |
if (radeon_connector->ddc_bus) { |
radeon_i2c_do_lock(radeon_connector->ddc_bus, 1); |
dret = radeon_ddc_probe(radeon_connector); |
radeon_i2c_do_lock(radeon_connector->ddc_bus, 0); |
} |
if (dret) { |
if (radeon_connector->edid) { |
kfree(radeon_connector->edid); |
1347,7 → 1343,7 |
radeon_connector->dac_load_detect = false; |
drm_connector_attach_property(&radeon_connector->base, |
rdev->mode_info.load_detect_property, |
radeon_connector->dac_load_detect); |
1); |
drm_connector_attach_property(&radeon_connector->base, |
rdev->mode_info.tv_std_property, |
radeon_combios_get_tv_info(rdev)); |
/drivers/video/drm/radeon/radeon_fb.c |
---|
146,8 → 146,8 |
struct radeon_framebuffer *rfb; |
struct drm_mode_fb_cmd mode_cmd; |
struct drm_gem_object *gobj = NULL; |
struct radeon_bo *rbo = NULL; |
// struct device *device = &rdev->pdev->dev; |
struct radeon_object *robj = NULL; |
void *device = NULL; //&rdev->pdev->dev; |
int size, aligned_size, ret; |
u64 fb_gpuaddr; |
void *fbptr = NULL; |
163,7 → 163,7 |
if ((surface_bpp == 24) && ASIC_IS_AVIVO(rdev)) |
surface_bpp = 32; |
mode_cmd.bpp = surface_bpp; |
mode_cmd.bpp = 32; |
/* need to align pitch with crtc limits */ |
mode_cmd.pitch = radeon_align_pitch(rdev, mode_cmd.width, mode_cmd.bpp, fb_tiled) * ((mode_cmd.bpp + 1) / 8); |
mode_cmd.depth = surface_depth; |
171,10 → 171,10 |
size = mode_cmd.pitch * mode_cmd.height; |
aligned_size = ALIGN(size, PAGE_SIZE); |
ret = radeon_gem_object_create(rdev, aligned_size, 0, |
ret = radeon_gem_fb_object_create(rdev, aligned_size, 0, |
RADEON_GEM_DOMAIN_VRAM, |
false, ttm_bo_type_kernel, |
&gobj); |
false, 0, |
false, &gobj); |
if (ret) { |
printk(KERN_ERR "failed to allocate framebuffer (%d %d)\n", |
surface_width, surface_height); |
181,30 → 181,8 |
ret = -ENOMEM; |
goto out; |
} |
rbo = gobj->driver_private; |
robj = gobj->driver_private; |
if (fb_tiled) |
tiling_flags = RADEON_TILING_MACRO; |
#ifdef __BIG_ENDIAN |
switch (mode_cmd.bpp) { |
case 32: |
tiling_flags |= RADEON_TILING_SWAP_32BIT; |
break; |
case 16: |
tiling_flags |= RADEON_TILING_SWAP_16BIT; |
default: |
break; |
} |
#endif |
if (tiling_flags) { |
ret = radeon_bo_set_tiling_flags(rbo, |
tiling_flags | RADEON_TILING_SURFACE, |
mode_cmd.pitch); |
if (ret) |
dev_err(rdev->dev, "FB failed to set tiling flags\n"); |
} |
mutex_lock(&rdev->ddev->struct_mutex); |
fb = radeon_framebuffer_create(rdev->ddev, &mode_cmd, gobj); |
if (fb == NULL) { |
212,21 → 190,12 |
ret = -ENOMEM; |
goto out_unref; |
} |
ret = radeon_bo_reserve(rbo, false); |
if (unlikely(ret != 0)) |
goto out_unref; |
ret = radeon_bo_pin(rbo, RADEON_GEM_DOMAIN_VRAM, &fb_gpuaddr); |
ret = radeon_object_pin(robj, RADEON_GEM_DOMAIN_VRAM, &fb_gpuaddr); |
if (ret) { |
radeon_bo_unreserve(rbo); |
printk(KERN_ERR "failed to pin framebuffer\n"); |
ret = -ENOMEM; |
goto out_unref; |
} |
if (fb_tiled) |
radeon_bo_check_tiling(rbo, 0, 0); |
ret = radeon_bo_kmap(rbo, &fbptr); |
radeon_bo_unreserve(rbo); |
if (ret) { |
goto out_unref; |
} |
list_add(&fb->filp_head, &rdev->ddev->mode_config.fb_kernel_list); |
233,9 → 202,9 |
*fb_p = fb; |
rfb = to_radeon_framebuffer(fb); |
rdev->fbdev_rfb = rfb; |
rdev->fbdev_rbo = rbo; |
rdev->fbdev_robj = robj; |
info = framebuffer_alloc(sizeof(struct radeon_fb_device), NULL); |
info = framebuffer_alloc(sizeof(struct radeon_fb_device), device); |
if (info == NULL) { |
ret = -ENOMEM; |
goto out_unref; |
254,7 → 223,14 |
if (ret) |
goto out_unref; |
// ret = radeon_object_kmap(robj, &fbptr); |
// if (ret) { |
// goto out_unref; |
// } |
fbptr = (void*)0xFE000000; // LFB_BASE |
strcpy(info->fix.id, "radeondrmfb"); |
drm_fb_helper_fill_fix(info, fb->pitch, fb->depth); |
301,13 → 277,9 |
return 0; |
out_unref: |
if (rbo) { |
ret = radeon_bo_reserve(rbo, false); |
if (likely(ret == 0)) { |
radeon_bo_kunmap(rbo); |
radeon_bo_unreserve(rbo); |
if (robj) { |
// radeon_object_kunmap(robj); |
} |
} |
if (fb && ret) { |
list_del(&fb->filp_head); |
// drm_gem_object_unreference(gobj); |
322,13 → 294,6 |
int radeonfb_probe(struct drm_device *dev) |
{ |
struct radeon_device *rdev = dev->dev_private; |
int bpp_sel = 32; |
/* select 8 bpp console on RN50 or 16MB cards */ |
if (ASIC_IS_RN50(rdev) || rdev->mc.real_vram_size <= (32*1024*1024)) |
bpp_sel = 8; |
return drm_fb_helper_single_fb_probe(dev, 32, &radeonfb_create); |
} |
336,8 → 301,7 |
{ |
struct fb_info *info; |
struct radeon_framebuffer *rfb = to_radeon_framebuffer(fb); |
struct radeon_bo *rbo; |
int r; |
struct radeon_object *robj; |
if (!fb) { |
return -EINVAL; |
345,17 → 309,12 |
info = fb->fbdev; |
if (info) { |
struct radeon_fb_device *rfbdev = info->par; |
rbo = rfb->obj->driver_private; |
robj = rfb->obj->driver_private; |
// unregister_framebuffer(info); |
r = radeon_bo_reserve(rbo, false); |
if (likely(r == 0)) { |
radeon_bo_kunmap(rbo); |
radeon_bo_unpin(rbo); |
radeon_bo_unreserve(rbo); |
// radeon_object_kunmap(robj); |
// radeon_object_unpin(robj); |
// framebuffer_release(info); |
} |
drm_fb_helper_free(&rfbdev->helper); |
framebuffer_release(info); |
} |
printk(KERN_INFO "unregistered panic notifier\n"); |
364,4 → 323,120 |
EXPORT_SYMBOL(radeonfb_remove); |
/** |
* Allocate a GEM object of the specified size with shmfs backing store |
*/ |
struct drm_gem_object * |
drm_gem_object_alloc(struct drm_device *dev, size_t size) |
{ |
struct drm_gem_object *obj; |
BUG_ON((size & (PAGE_SIZE - 1)) != 0); |
obj = kzalloc(sizeof(*obj), GFP_KERNEL); |
obj->dev = dev; |
// obj->filp = shmem_file_setup("drm mm object", size, VM_NORESERVE); |
// if (IS_ERR(obj->filp)) { |
// kfree(obj); |
// return NULL; |
// } |
// kref_init(&obj->refcount); |
// kref_init(&obj->handlecount); |
obj->size = size; |
// if (dev->driver->gem_init_object != NULL && |
// dev->driver->gem_init_object(obj) != 0) { |
// fput(obj->filp); |
// kfree(obj); |
// return NULL; |
// } |
// atomic_inc(&dev->object_count); |
// atomic_add(obj->size, &dev->object_memory); |
return obj; |
} |
int radeon_gem_fb_object_create(struct radeon_device *rdev, int size, |
int alignment, int initial_domain, |
bool discardable, bool kernel, |
bool interruptible, |
struct drm_gem_object **obj) |
{ |
struct drm_gem_object *gobj; |
struct radeon_object *robj; |
*obj = NULL; |
gobj = drm_gem_object_alloc(rdev->ddev, size); |
if (!gobj) { |
return -ENOMEM; |
} |
/* At least align on page size */ |
if (alignment < PAGE_SIZE) { |
alignment = PAGE_SIZE; |
} |
robj = kzalloc(sizeof(struct radeon_object), GFP_KERNEL); |
if (!robj) { |
DRM_ERROR("Failed to allocate GEM object (%d, %d, %u)\n", |
size, initial_domain, alignment); |
// mutex_lock(&rdev->ddev->struct_mutex); |
// drm_gem_object_unreference(gobj); |
// mutex_unlock(&rdev->ddev->struct_mutex); |
return -ENOMEM;; |
} |
robj->rdev = rdev; |
robj->gobj = gobj; |
INIT_LIST_HEAD(&robj->list); |
robj->flags = TTM_PL_FLAG_VRAM; |
struct drm_mm_node *vm_node; |
vm_node = kzalloc(sizeof(*vm_node),0); |
vm_node->free = 0; |
vm_node->size = 0xC00000 >> 12; |
vm_node->start = 0; |
vm_node->mm = NULL; |
robj->mm_node = vm_node; |
robj->vm_addr = ((uint32_t)robj->mm_node->start); |
gobj->driver_private = robj; |
*obj = gobj; |
return 0; |
} |
struct fb_info *framebuffer_alloc(size_t size, void *dev) |
{ |
#define BYTES_PER_LONG (BITS_PER_LONG/8) |
#define PADDING (BYTES_PER_LONG - (sizeof(struct fb_info) % BYTES_PER_LONG)) |
int fb_info_size = sizeof(struct fb_info); |
struct fb_info *info; |
char *p; |
if (size) |
fb_info_size += PADDING; |
p = kzalloc(fb_info_size + size, GFP_KERNEL); |
if (!p) |
return NULL; |
info = (struct fb_info *) p; |
if (size) |
info->par = p + fb_info_size; |
return info; |
#undef PADDING |
#undef BYTES_PER_LONG |
} |
/drivers/video/drm/radeon/rdisplay.c |
---|
29,21 → 29,17 |
rdev = (struct radeon_device *)rdisplay->ddev->dev_private; |
r = radeon_bo_create(rdev, NULL, CURSOR_WIDTH*CURSOR_HEIGHT*4, |
false, RADEON_GEM_DOMAIN_VRAM, &cursor->robj); |
r = radeon_object_create(rdev, NULL, CURSOR_WIDTH*CURSOR_HEIGHT*4, |
false, |
RADEON_GEM_DOMAIN_VRAM, |
false, &cursor->robj); |
if (unlikely(r != 0)) |
return r; |
r = radeon_bo_reserve(cursor->robj, false); |
if (unlikely(r != 0)) |
return r; |
radeon_object_pin(cursor->robj, TTM_PL_FLAG_VRAM, NULL); |
r = radeon_bo_pin(cursor->robj, RADEON_GEM_DOMAIN_VRAM, NULL); |
if (unlikely(r != 0)) |
return r; |
r = radeon_bo_kmap(cursor->robj, (void**)&bits); |
r = radeon_object_kmap(cursor->robj, &bits); |
if (r) { |
DRM_ERROR("radeon: failed to map cursor (%d).\n", r); |
return r; |
61,7 → 57,7 |
for(i = 0; i < CURSOR_WIDTH*(CURSOR_HEIGHT-32); i++) |
*bits++ = 0; |
radeon_bo_kunmap(cursor->robj); |
radeon_object_kunmap(cursor->robj); |
// cursor->header.destroy = destroy_cursor; |
71,7 → 67,7 |
void fini_cursor(cursor_t *cursor) |
{ |
list_del(&cursor->list); |
radeon_bo_unpin(cursor->robj); |
radeon_object_unpin(cursor->robj); |
KernelFree(cursor->data); |
__DestroyObject(cursor); |
}; |
104,7 → 100,7 |
old = rdisplay->cursor; |
rdisplay->cursor = cursor; |
gpu_addr = radeon_bo_gpu_offset(cursor->robj); |
// gpu_addr = cursor->robj->gpu_addr; |
if (ASIC_IS_AVIVO(rdev)) |
WREG32(AVIVO_D1CUR_SURFACE_ADDRESS, gpu_addr); |
153,40 → 149,24 |
if (ASIC_IS_AVIVO(rdev)) |
{ |
int w = 32; |
int i = 0; |
WREG32(AVIVO_D1CUR_POSITION, (x << 16) | y); |
WREG32(AVIVO_D1CUR_HOT_SPOT, (hot_x << 16) | hot_y); |
WREG32(AVIVO_D1CUR_SIZE, ((w - 1) << 16) | 31); |
} else { |
uint32_t gpu_addr; |
int xorg =0, yorg=0; |
x = x - hot_x; |
y = y - hot_y; |
if( x < 0 ) |
{ |
xorg = -x + 1; |
x = 0; |
} |
if( y < 0 ) |
{ |
yorg = -hot_y + 1; |
y = 0; |
}; |
WREG32(RADEON_CUR_HORZ_VERT_OFF, |
(RADEON_CUR_LOCK | (xorg << 16) | yorg )); |
(RADEON_CUR_LOCK | (hot_x << 16) | hot_y )); |
WREG32(RADEON_CUR_HORZ_VERT_POSN, |
(RADEON_CUR_LOCK | (x << 16) | y)); |
gpu_addr = radeon_bo_gpu_offset(cursor->robj); |
// gpu_addr = cursor->robj->gpu_addr; |
/* offset is from DISP(2)_BASE_ADDRESS */ |
WREG32(RADEON_CUR_OFFSET, |
(gpu_addr - rdev->mc.vram_location + (yorg * 256))); |
(gpu_addr - rdev->mc.vram_location + (hot_y * 256))); |
} |
radeon_lock_cursor(false); |
} |
196,7 → 176,7 |
}; |
bool init_display(struct radeon_device *rdev, videomode_t *usermode) |
bool init_display(struct radeon_device *rdev, mode_t *usermode) |
{ |
struct drm_device *dev; |
236,34 → 216,4 |
}; |
struct fb_info *framebuffer_alloc(size_t size, struct device *dev) |
{ |
#define BYTES_PER_LONG (BITS_PER_LONG/8) |
#define PADDING (BYTES_PER_LONG - (sizeof(struct fb_info) % BYTES_PER_LONG)) |
int fb_info_size = sizeof(struct fb_info); |
struct fb_info *info; |
char *p; |
if (size) |
fb_info_size += PADDING; |
p = kzalloc(fb_info_size + size, GFP_KERNEL); |
if (!p) |
return NULL; |
info = (struct fb_info *) p; |
if (size) |
info->par = p + fb_info_size; |
return info; |
#undef PADDING |
#undef BYTES_PER_LONG |
} |
void framebuffer_release(struct fb_info *info) |
{ |
kfree(info); |
} |
/drivers/video/drm/radeon/rdisplay_kms.c |
---|
78,7 → 78,7 |
old = rdisplay->cursor; |
rdisplay->cursor = cursor; |
gpu_addr = radeon_bo_gpu_offset(cursor->robj); |
// gpu_addr = cursor->robj->gpu_addr; |
if (ASIC_IS_AVIVO(rdev)) |
WREG32(AVIVO_D1CUR_SURFACE_ADDRESS + radeon_crtc->crtc_offset, gpu_addr); |
148,34 → 148,14 |
if (crtc->mode.flags & DRM_MODE_FLAG_DBLSCAN) |
y *= 2; |
uint32_t gpu_addr; |
int xorg =0, yorg=0; |
x = x - hot_x; |
y = y - hot_y; |
if( x < 0 ) |
{ |
xorg = -x + 1; |
x = 0; |
} |
if( y < 0 ) |
{ |
yorg = -hot_y + 1; |
y = 0; |
}; |
WREG32(RADEON_CUR_HORZ_VERT_OFF, |
(RADEON_CUR_LOCK | (xorg << 16) | yorg )); |
WREG32(RADEON_CUR_HORZ_VERT_POSN, |
WREG32(RADEON_CUR_HORZ_VERT_OFF + radeon_crtc->crtc_offset, |
(RADEON_CUR_LOCK | (hot_x << 16) | hot_y )); |
WREG32(RADEON_CUR_HORZ_VERT_POSN + radeon_crtc->crtc_offset, |
(RADEON_CUR_LOCK | (x << 16) | y)); |
gpu_addr = radeon_bo_gpu_offset(cursor->robj); |
/* offset is from DISP(2)_BASE_ADDRESS */ |
WREG32(RADEON_CUR_OFFSET, |
(gpu_addr - rdev->mc.vram_location + (yorg * 256))); |
WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, |
(radeon_crtc->legacy_cursor_offset + (hot_y * 256))); |
} |
radeon_lock_cursor_kms(crtc, false); |
} |
467,40 → 447,3 |
return err; |
}; |
#if 0 |
void drm_helper_disable_unused_functions(struct drm_device *dev) |
{ |
struct drm_encoder *encoder; |
struct drm_connector *connector; |
struct drm_encoder_helper_funcs *encoder_funcs; |
struct drm_crtc *crtc; |
list_for_each_entry(connector, &dev->mode_config.connector_list, head) { |
if (!connector->encoder) |
continue; |
if (connector->status == connector_status_disconnected) |
connector->encoder = NULL; |
} |
list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) { |
encoder_funcs = encoder->helper_private; |
if (!drm_helper_encoder_in_use(encoder)) { |
if (encoder_funcs->disable) |
(*encoder_funcs->disable)(encoder); |
else |
(*encoder_funcs->dpms)(encoder, DRM_MODE_DPMS_OFF); |
/* disconnector encoder from any connector */ |
encoder->crtc = NULL; |
} |
} |
list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) { |
struct drm_crtc_helper_funcs *crtc_funcs = crtc->helper_private; |
crtc->enabled = drm_helper_crtc_in_use(crtc); |
if (!crtc->enabled) { |
crtc_funcs->dpms(crtc, DRM_MODE_DPMS_OFF); |
crtc->fb = NULL; |
} |
} |
} |
#endif |
/drivers/video/drm/radeon/rs400.c |
---|
223,22 → 223,6 |
return 0; |
} |
int rs400_mc_wait_for_idle(struct radeon_device *rdev) |
{ |
unsigned i; |
uint32_t tmp; |
for (i = 0; i < rdev->usec_timeout; i++) { |
/* read MC_STATUS */ |
tmp = RREG32(0x0150); |
if (tmp & (1 << 2)) { |
return 0; |
} |
DRM_UDELAY(1); |
} |
return -1; |
} |
void rs400_gpu_init(struct radeon_device *rdev) |
{ |
/* FIXME: HDP same place on rs400 ? */ |
245,9 → 229,9 |
r100_hdp_reset(rdev); |
/* FIXME: is this correct ? */ |
r420_pipes_init(rdev); |
if (rs400_mc_wait_for_idle(rdev)) { |
printk(KERN_WARNING "rs400: Failed to wait MC idle while " |
"programming pipes. Bad things might happen. %08x\n", RREG32(0x150)); |
if (r300_mc_wait_for_idle(rdev)) { |
printk(KERN_WARNING "Failed to wait MC idle while " |
"programming pipes. Bad things might happen.\n"); |
} |
} |
386,8 → 370,8 |
r100_mc_stop(rdev, &save); |
/* Wait for mc idle */ |
if (rs400_mc_wait_for_idle(rdev)) |
dev_warn(rdev->dev, "rs400: Wait MC idle timeout before updating MC.\n"); |
if (r300_mc_wait_for_idle(rdev)) |
dev_warn(rdev->dev, "Wait MC idle timeout before updating MC.\n"); |
WREG32(R_000148_MC_FB_LOCATION, |
S_000148_MC_FB_START(rdev->mc.vram_start >> 16) | |
S_000148_MC_FB_TOP(rdev->mc.vram_end >> 16)); |
/drivers/video/drm/radeon/rs600.c |
---|
272,14 → 272,10 |
tmp = RREG32_MC(R_000009_MC_CNTL1); |
WREG32_MC(R_000009_MC_CNTL1, tmp & C_000009_ENABLE_PAGE_TABLES); |
if (rdev->gart.table.vram.robj) { |
r = radeon_bo_reserve(rdev->gart.table.vram.robj, false); |
if (r == 0) { |
radeon_bo_kunmap(rdev->gart.table.vram.robj); |
radeon_bo_unpin(rdev->gart.table.vram.robj); |
radeon_bo_unreserve(rdev->gart.table.vram.robj); |
// radeon_object_kunmap(rdev->gart.table.vram.robj); |
// radeon_object_unpin(rdev->gart.table.vram.robj); |
} |
} |
} |
void rs600_gart_fini(struct radeon_device *rdev) |
{ |
/drivers/video/drm/radeon/rv770.c |
---|
113,19 → 113,15 |
WREG32(MC_VM_MB_L1_TLB2_CNTL, tmp); |
WREG32(MC_VM_MB_L1_TLB3_CNTL, tmp); |
if (rdev->gart.table.vram.robj) { |
r = radeon_bo_reserve(rdev->gart.table.vram.robj, false); |
if (likely(r == 0)) { |
radeon_bo_kunmap(rdev->gart.table.vram.robj); |
radeon_bo_unpin(rdev->gart.table.vram.robj); |
radeon_bo_unreserve(rdev->gart.table.vram.robj); |
// radeon_object_kunmap(rdev->gart.table.vram.robj); |
// radeon_object_unpin(rdev->gart.table.vram.robj); |
} |
} |
} |
void rv770_pcie_gart_fini(struct radeon_device *rdev) |
{ |
rv770_pcie_gart_disable(rdev); |
radeon_gart_table_vram_free(rdev); |
// radeon_gart_table_vram_free(rdev); |
radeon_gart_fini(rdev); |
} |
881,7 → 877,6 |
} |
rv770_gpu_init(rdev); |
// r = radeon_object_pin(rdev->r600_blit.shader_obj, RADEON_GEM_DOMAIN_VRAM, |
// &rdev->r600_blit.shader_gpu_addr); |
// if (r) { |
/drivers/video/drm/radeon/atombios_crtc.c |
---|
305,6 → 305,7 |
args.susModeMiscInfo.usAccess = cpu_to_le16(misc); |
args.ucCRTC = radeon_crtc->crtc_id; |
printk("executing set crtc dtd timing\n"); |
atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); |
} |
344,6 → 345,7 |
args.susModeMiscInfo.usAccess = cpu_to_le16(misc); |
args.ucCRTC = radeon_crtc->crtc_id; |
printk("executing set crtc timing\n"); |
atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); |
} |
405,57 → 407,59 |
} |
} |
union adjust_pixel_clock { |
ADJUST_DISPLAY_PLL_PS_ALLOCATION v1; |
}; |
static u32 atombios_adjust_pll(struct drm_crtc *crtc, |
struct drm_display_mode *mode, |
struct radeon_pll *pll) |
void atombios_crtc_set_pll(struct drm_crtc *crtc, struct drm_display_mode *mode) |
{ |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
struct drm_device *dev = crtc->dev; |
struct radeon_device *rdev = dev->dev_private; |
struct drm_encoder *encoder = NULL; |
struct radeon_encoder *radeon_encoder = NULL; |
u32 adjusted_clock = mode->clock; |
uint8_t frev, crev; |
int index; |
SET_PIXEL_CLOCK_PS_ALLOCATION args; |
PIXEL_CLOCK_PARAMETERS *spc1_ptr; |
PIXEL_CLOCK_PARAMETERS_V2 *spc2_ptr; |
PIXEL_CLOCK_PARAMETERS_V3 *spc3_ptr; |
uint32_t pll_clock = mode->clock; |
uint32_t adjusted_clock; |
uint32_t ref_div = 0, fb_div = 0, frac_fb_div = 0, post_div = 0; |
struct radeon_pll *pll; |
int pll_flags = 0; |
/* reset the pll flags */ |
pll->flags = 0; |
memset(&args, 0, sizeof(args)); |
if (ASIC_IS_AVIVO(rdev)) { |
if ((rdev->family == CHIP_RS600) || |
(rdev->family == CHIP_RS690) || |
(rdev->family == CHIP_RS740)) |
pll->flags |= (RADEON_PLL_USE_FRAC_FB_DIV | |
pll_flags |= (RADEON_PLL_USE_FRAC_FB_DIV | |
RADEON_PLL_PREFER_CLOSEST_LOWER); |
if (ASIC_IS_DCE32(rdev) && mode->clock > 200000) /* range limits??? */ |
pll->flags |= RADEON_PLL_PREFER_HIGH_FB_DIV; |
pll_flags |= RADEON_PLL_PREFER_HIGH_FB_DIV; |
else |
pll->flags |= RADEON_PLL_PREFER_LOW_REF_DIV; |
pll_flags |= RADEON_PLL_PREFER_LOW_REF_DIV; |
} else { |
pll->flags |= RADEON_PLL_LEGACY; |
pll_flags |= RADEON_PLL_LEGACY; |
if (mode->clock > 200000) /* range limits??? */ |
pll->flags |= RADEON_PLL_PREFER_HIGH_FB_DIV; |
pll_flags |= RADEON_PLL_PREFER_HIGH_FB_DIV; |
else |
pll->flags |= RADEON_PLL_PREFER_LOW_REF_DIV; |
pll_flags |= RADEON_PLL_PREFER_LOW_REF_DIV; |
} |
list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) { |
if (encoder->crtc == crtc) { |
if (!ASIC_IS_AVIVO(rdev)) { |
if (encoder->encoder_type != |
DRM_MODE_ENCODER_DAC) |
pll_flags |= RADEON_PLL_NO_ODD_POST_DIV; |
if (encoder->encoder_type == |
DRM_MODE_ENCODER_LVDS) |
pll_flags |= RADEON_PLL_USE_REF_DIV; |
} |
radeon_encoder = to_radeon_encoder(encoder); |
if (ASIC_IS_AVIVO(rdev)) { |
/* DVO wants 2x pixel clock if the DVO chip is in 12 bit mode */ |
if (radeon_encoder->encoder_id == ENCODER_OBJECT_ID_INTERNAL_KLDSCP_DVO1) |
adjusted_clock = mode->clock * 2; |
} else { |
if (encoder->encoder_type != DRM_MODE_ENCODER_DAC) |
pll->flags |= RADEON_PLL_NO_ODD_POST_DIV; |
if (encoder->encoder_type == DRM_MODE_ENCODER_LVDS) |
pll->flags |= RADEON_PLL_USE_REF_DIV; |
} |
break; |
} |
} |
465,101 → 469,46 |
* special hw requirements. |
*/ |
if (ASIC_IS_DCE3(rdev)) { |
union adjust_pixel_clock args; |
struct radeon_encoder_atom_dig *dig; |
u8 frev, crev; |
int index; |
ADJUST_DISPLAY_PLL_PS_ALLOCATION adjust_pll_args; |
if (!radeon_encoder->enc_priv) |
return adjusted_clock; |
dig = radeon_encoder->enc_priv; |
if (!encoder) |
return; |
memset(&adjust_pll_args, 0, sizeof(adjust_pll_args)); |
adjust_pll_args.usPixelClock = cpu_to_le16(mode->clock / 10); |
adjust_pll_args.ucTransmitterID = radeon_encoder->encoder_id; |
adjust_pll_args.ucEncodeMode = atombios_get_encoder_mode(encoder); |
index = GetIndexIntoMasterTable(COMMAND, AdjustDisplayPll); |
atom_parse_cmd_header(rdev->mode_info.atom_context, index, &frev, |
&crev); |
memset(&args, 0, sizeof(args)); |
switch (frev) { |
case 1: |
switch (crev) { |
case 1: |
case 2: |
args.v1.usPixelClock = cpu_to_le16(mode->clock / 10); |
args.v1.ucTransmitterID = radeon_encoder->encoder_id; |
args.v1.ucEncodeMode = atombios_get_encoder_mode(encoder); |
atom_execute_table(rdev->mode_info.atom_context, |
index, (uint32_t *)&args); |
adjusted_clock = le16_to_cpu(args.v1.usPixelClock) * 10; |
break; |
default: |
DRM_ERROR("Unknown table version %d %d\n", frev, crev); |
return adjusted_clock; |
index, (uint32_t *)&adjust_pll_args); |
adjusted_clock = le16_to_cpu(adjust_pll_args.usPixelClock) * 10; |
} else { |
/* DVO wants 2x pixel clock if the DVO chip is in 12 bit mode */ |
if (ASIC_IS_AVIVO(rdev) && |
(radeon_encoder->encoder_id == ENCODER_OBJECT_ID_INTERNAL_KLDSCP_DVO1)) |
adjusted_clock = mode->clock * 2; |
else |
adjusted_clock = mode->clock; |
} |
break; |
default: |
DRM_ERROR("Unknown table version %d %d\n", frev, crev); |
return adjusted_clock; |
} |
} |
return adjusted_clock; |
} |
union set_pixel_clock { |
SET_PIXEL_CLOCK_PS_ALLOCATION base; |
PIXEL_CLOCK_PARAMETERS v1; |
PIXEL_CLOCK_PARAMETERS_V2 v2; |
PIXEL_CLOCK_PARAMETERS_V3 v3; |
}; |
void atombios_crtc_set_pll(struct drm_crtc *crtc, struct drm_display_mode *mode) |
{ |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
struct drm_device *dev = crtc->dev; |
struct radeon_device *rdev = dev->dev_private; |
struct drm_encoder *encoder = NULL; |
struct radeon_encoder *radeon_encoder = NULL; |
u8 frev, crev; |
int index; |
union set_pixel_clock args; |
u32 pll_clock = mode->clock; |
u32 ref_div = 0, fb_div = 0, frac_fb_div = 0, post_div = 0; |
struct radeon_pll *pll; |
u32 adjusted_clock; |
memset(&args, 0, sizeof(args)); |
list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) { |
if (encoder->crtc == crtc) { |
radeon_encoder = to_radeon_encoder(encoder); |
break; |
} |
} |
if (!radeon_encoder) |
return; |
if (radeon_crtc->crtc_id == 0) |
pll = &rdev->clock.p1pll; |
else |
pll = &rdev->clock.p2pll; |
/* adjust pixel clock as needed */ |
adjusted_clock = atombios_adjust_pll(crtc, mode, pll); |
if (ASIC_IS_AVIVO(rdev)) { |
if (radeon_new_pll) |
radeon_compute_pll_avivo(pll, adjusted_clock, &pll_clock, |
&fb_div, &frac_fb_div, |
&ref_div, &post_div); |
&ref_div, &post_div, pll_flags); |
else |
radeon_compute_pll(pll, adjusted_clock, &pll_clock, |
&fb_div, &frac_fb_div, |
&ref_div, &post_div); |
&ref_div, &post_div, pll_flags); |
} else |
radeon_compute_pll(pll, adjusted_clock, &pll_clock, &fb_div, &frac_fb_div, |
&ref_div, &post_div); |
&ref_div, &post_div, pll_flags); |
index = GetIndexIntoMasterTable(COMMAND, SetPixelClock); |
atom_parse_cmd_header(rdev->mode_info.atom_context, index, &frev, |
569,38 → 518,45 |
case 1: |
switch (crev) { |
case 1: |
args.v1.usPixelClock = cpu_to_le16(mode->clock / 10); |
args.v1.usRefDiv = cpu_to_le16(ref_div); |
args.v1.usFbDiv = cpu_to_le16(fb_div); |
args.v1.ucFracFbDiv = frac_fb_div; |
args.v1.ucPostDiv = post_div; |
args.v1.ucPpll = |
spc1_ptr = (PIXEL_CLOCK_PARAMETERS *) & args.sPCLKInput; |
spc1_ptr->usPixelClock = cpu_to_le16(mode->clock / 10); |
spc1_ptr->usRefDiv = cpu_to_le16(ref_div); |
spc1_ptr->usFbDiv = cpu_to_le16(fb_div); |
spc1_ptr->ucFracFbDiv = frac_fb_div; |
spc1_ptr->ucPostDiv = post_div; |
spc1_ptr->ucPpll = |
radeon_crtc->crtc_id ? ATOM_PPLL2 : ATOM_PPLL1; |
args.v1.ucCRTC = radeon_crtc->crtc_id; |
args.v1.ucRefDivSrc = 1; |
spc1_ptr->ucCRTC = radeon_crtc->crtc_id; |
spc1_ptr->ucRefDivSrc = 1; |
break; |
case 2: |
args.v2.usPixelClock = cpu_to_le16(mode->clock / 10); |
args.v2.usRefDiv = cpu_to_le16(ref_div); |
args.v2.usFbDiv = cpu_to_le16(fb_div); |
args.v2.ucFracFbDiv = frac_fb_div; |
args.v2.ucPostDiv = post_div; |
args.v2.ucPpll = |
spc2_ptr = |
(PIXEL_CLOCK_PARAMETERS_V2 *) & args.sPCLKInput; |
spc2_ptr->usPixelClock = cpu_to_le16(mode->clock / 10); |
spc2_ptr->usRefDiv = cpu_to_le16(ref_div); |
spc2_ptr->usFbDiv = cpu_to_le16(fb_div); |
spc2_ptr->ucFracFbDiv = frac_fb_div; |
spc2_ptr->ucPostDiv = post_div; |
spc2_ptr->ucPpll = |
radeon_crtc->crtc_id ? ATOM_PPLL2 : ATOM_PPLL1; |
args.v2.ucCRTC = radeon_crtc->crtc_id; |
args.v2.ucRefDivSrc = 1; |
spc2_ptr->ucCRTC = radeon_crtc->crtc_id; |
spc2_ptr->ucRefDivSrc = 1; |
break; |
case 3: |
args.v3.usPixelClock = cpu_to_le16(mode->clock / 10); |
args.v3.usRefDiv = cpu_to_le16(ref_div); |
args.v3.usFbDiv = cpu_to_le16(fb_div); |
args.v3.ucFracFbDiv = frac_fb_div; |
args.v3.ucPostDiv = post_div; |
args.v3.ucPpll = |
if (!encoder) |
return; |
spc3_ptr = |
(PIXEL_CLOCK_PARAMETERS_V3 *) & args.sPCLKInput; |
spc3_ptr->usPixelClock = cpu_to_le16(mode->clock / 10); |
spc3_ptr->usRefDiv = cpu_to_le16(ref_div); |
spc3_ptr->usFbDiv = cpu_to_le16(fb_div); |
spc3_ptr->ucFracFbDiv = frac_fb_div; |
spc3_ptr->ucPostDiv = post_div; |
spc3_ptr->ucPpll = |
radeon_crtc->crtc_id ? ATOM_PPLL2 : ATOM_PPLL1; |
args.v3.ucMiscInfo = (radeon_crtc->crtc_id << 2); |
args.v3.ucTransmitterId = radeon_encoder->encoder_id; |
args.v3.ucEncoderMode = |
spc3_ptr->ucMiscInfo = (radeon_crtc->crtc_id << 2); |
spc3_ptr->ucTransmitterId = radeon_encoder->encoder_id; |
spc3_ptr->ucEncoderMode = |
atombios_get_encoder_mode(encoder); |
break; |
default: |
613,10 → 569,11 |
return; |
} |
printk("executing set pll\n"); |
atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); |
} |
static int avivo_crtc_set_base(struct drm_crtc *crtc, int x, int y, |
int atombios_crtc_set_base(struct drm_crtc *crtc, int x, int y, |
struct drm_framebuffer *old_fb) |
{ |
ENTER(); |
641,18 → 598,15 |
/* Pin framebuffer & get tilling informations */ |
obj = radeon_fb->obj; |
rbo = obj->driver_private; |
r = radeon_bo_reserve(rbo, false); |
if (unlikely(r != 0)) |
return r; |
r = radeon_bo_pin(rbo, RADEON_GEM_DOMAIN_VRAM, &fb_location); |
if (unlikely(r != 0)) { |
radeon_bo_unreserve(rbo); |
return -EINVAL; |
} |
radeon_bo_get_tiling_flags(rbo, &tiling_flags, NULL); |
radeon_bo_unreserve(rbo); |
obj_priv = obj->driver_private; |
// if (radeon_gem_object_pin(obj, RADEON_GEM_DOMAIN_VRAM, &fb_location)) { |
// return -EINVAL; |
// } |
fb_location = rdev->mc.vram_location; |
tiling_flags = 0; |
switch (crtc->fb->bits_per_pixel) { |
case 8: |
fb_format = |
733,15 → 687,10 |
else |
WREG32(AVIVO_D1MODE_DATA_FORMAT + radeon_crtc->crtc_offset, 0); |
if (old_fb && old_fb != crtc->fb) { |
radeon_fb = to_radeon_framebuffer(old_fb); |
rbo = radeon_fb->obj->driver_private; |
r = radeon_bo_reserve(rbo, false); |
if (unlikely(r != 0)) |
return r; |
radeon_bo_unpin(rbo); |
radeon_bo_unreserve(rbo); |
} |
// if (old_fb && old_fb != crtc->fb) { |
// radeon_fb = to_radeon_framebuffer(old_fb); |
// radeon_gem_object_unpin(radeon_fb->obj); |
// } |
/* Bytes per pixel may have changed */ |
radeon_bandwidth_update(rdev); |
751,42 → 700,6 |
return 0; |
} |
int atombios_crtc_set_base(struct drm_crtc *crtc, int x, int y, |
struct drm_framebuffer *old_fb) |
{ |
struct drm_device *dev = crtc->dev; |
struct radeon_device *rdev = dev->dev_private; |
if (ASIC_IS_AVIVO(rdev)) |
return avivo_crtc_set_base(crtc, x, y, old_fb); |
else |
return radeon_crtc_set_base(crtc, x, y, old_fb); |
} |
/* properly set additional regs when using atombios */ |
static void radeon_legacy_atom_fixup(struct drm_crtc *crtc) |
{ |
struct drm_device *dev = crtc->dev; |
struct radeon_device *rdev = dev->dev_private; |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
u32 disp_merge_cntl; |
switch (radeon_crtc->crtc_id) { |
case 0: |
disp_merge_cntl = RREG32(RADEON_DISP_MERGE_CNTL); |
disp_merge_cntl &= ~RADEON_DISP_RGB_OFFSET_EN; |
WREG32(RADEON_DISP_MERGE_CNTL, disp_merge_cntl); |
break; |
case 1: |
disp_merge_cntl = RREG32(RADEON_DISP2_MERGE_CNTL); |
disp_merge_cntl &= ~RADEON_DISP2_RGB_OFFSET_EN; |
WREG32(RADEON_DISP2_MERGE_CNTL, disp_merge_cntl); |
WREG32(RADEON_FP_H2_SYNC_STRT_WID, RREG32(RADEON_CRTC2_H_SYNC_STRT_WID)); |
WREG32(RADEON_FP_V2_SYNC_STRT_WID, RREG32(RADEON_CRTC2_V_SYNC_STRT_WID)); |
break; |
} |
} |
int atombios_crtc_mode_set(struct drm_crtc *crtc, |
struct drm_display_mode *mode, |
struct drm_display_mode *adjusted_mode, |
808,8 → 721,8 |
else { |
if (radeon_crtc->crtc_id == 0) |
atombios_set_crtc_dtd_timing(crtc, adjusted_mode); |
atombios_crtc_set_base(crtc, x, y, old_fb); |
radeon_legacy_atom_fixup(crtc); |
radeon_crtc_set_base(crtc, x, y, old_fb); |
radeon_legacy_atom_set_surface(crtc); |
} |
atombios_overscan_setup(crtc, mode, adjusted_mode); |
atombios_scaler_setup(crtc); |
827,8 → 740,8 |
static void atombios_crtc_prepare(struct drm_crtc *crtc) |
{ |
atombios_crtc_dpms(crtc, DRM_MODE_DPMS_OFF); |
atombios_lock_crtc(crtc, 1); |
atombios_crtc_dpms(crtc, DRM_MODE_DPMS_OFF); |
} |
static void atombios_crtc_commit(struct drm_crtc *crtc) |
/drivers/video/drm/radeon/radeon_atombios.c |
---|
114,7 → 114,6 |
i2c.i2c_id = gpio->sucI2cId.ucAccess; |
i2c.valid = true; |
break; |
} |
} |
346,9 → 345,7 |
DRM_MODE_CONNECTOR_Unknown, |
DRM_MODE_CONNECTOR_Unknown, |
DRM_MODE_CONNECTOR_Unknown, |
DRM_MODE_CONNECTOR_DisplayPort, |
DRM_MODE_CONNECTOR_eDP, |
DRM_MODE_CONNECTOR_Unknown |
DRM_MODE_CONNECTOR_DisplayPort |
}; |
bool radeon_get_atom_connector_info_from_object_table(struct drm_device *dev) |
748,7 → 745,8 |
else |
radeon_add_legacy_encoder(dev, |
radeon_get_encoder_id(dev, |
(1 << i), |
(1 << |
i), |
dac), |
(1 << i)); |
} |
760,30 → 758,32 |
if (bios_connectors[j].valid && (i != j)) { |
if (bios_connectors[i].line_mux == |
bios_connectors[j].line_mux) { |
/* make sure not to combine LVDS */ |
if (bios_connectors[i].devices & (ATOM_DEVICE_LCD_SUPPORT)) { |
bios_connectors[i].line_mux = 53; |
bios_connectors[i].ddc_bus.valid = false; |
continue; |
} |
if (bios_connectors[j].devices & (ATOM_DEVICE_LCD_SUPPORT)) { |
bios_connectors[j].line_mux = 53; |
bios_connectors[j].ddc_bus.valid = false; |
continue; |
} |
/* combine analog and digital for DVI-I */ |
if (((bios_connectors[i].devices & (ATOM_DEVICE_DFP_SUPPORT)) && |
(bios_connectors[j].devices & (ATOM_DEVICE_CRT_SUPPORT))) || |
((bios_connectors[j].devices & (ATOM_DEVICE_DFP_SUPPORT)) && |
(bios_connectors[i].devices & (ATOM_DEVICE_CRT_SUPPORT)))) { |
bios_connectors[i].devices |= |
bios_connectors[j].devices; |
bios_connectors[i].connector_type = |
if (((bios_connectors[i]. |
devices & |
(ATOM_DEVICE_DFP_SUPPORT)) |
&& (bios_connectors[j]. |
devices & |
(ATOM_DEVICE_CRT_SUPPORT))) |
|| |
((bios_connectors[j]. |
devices & |
(ATOM_DEVICE_DFP_SUPPORT)) |
&& (bios_connectors[i]. |
devices & |
(ATOM_DEVICE_CRT_SUPPORT)))) { |
bios_connectors[i]. |
devices |= |
bios_connectors[j]. |
devices; |
bios_connectors[i]. |
connector_type = |
DRM_MODE_CONNECTOR_DVII; |
if (bios_connectors[j].devices & (ATOM_DEVICE_DFP_SUPPORT)) |
if (bios_connectors[j].devices & |
(ATOM_DEVICE_DFP_SUPPORT)) |
bios_connectors[i].hpd = |
bios_connectors[j].hpd; |
bios_connectors[j].valid = false; |
bios_connectors[j]. |
valid = false; |
} |
} |
} |
938,43 → 938,6 |
return false; |
} |
union igp_info { |
struct _ATOM_INTEGRATED_SYSTEM_INFO info; |
struct _ATOM_INTEGRATED_SYSTEM_INFO_V2 info_2; |
}; |
bool radeon_atombios_sideport_present(struct radeon_device *rdev) |
{ |
struct radeon_mode_info *mode_info = &rdev->mode_info; |
int index = GetIndexIntoMasterTable(DATA, IntegratedSystemInfo); |
union igp_info *igp_info; |
u8 frev, crev; |
u16 data_offset; |
atom_parse_data_header(mode_info->atom_context, index, NULL, &frev, |
&crev, &data_offset); |
igp_info = (union igp_info *)(mode_info->atom_context->bios + |
data_offset); |
if (igp_info) { |
switch (crev) { |
case 1: |
if (igp_info->info.ucMemoryType & 0xf0) |
return true; |
break; |
case 2: |
if (igp_info->info_2.ucMemoryType & 0x0f) |
return true; |
break; |
default: |
DRM_ERROR("Unsupported IGP table: %d %d\n", frev, crev); |
break; |
} |
} |
return false; |
} |
bool radeon_atombios_get_tmds_info(struct radeon_encoder *encoder, |
struct radeon_encoder_int_tmds *tmds) |
{ |
1066,7 → 1029,6 |
ss->delay = ss_info->asSS_Info[i].ucSS_Delay; |
ss->range = ss_info->asSS_Info[i].ucSS_Range; |
ss->refdiv = ss_info->asSS_Info[i].ucRecommendedRef_Div; |
break; |
} |
} |
} |
1272,61 → 1234,6 |
return true; |
} |
enum radeon_tv_std |
radeon_atombios_get_tv_info(struct radeon_device *rdev) |
{ |
struct radeon_mode_info *mode_info = &rdev->mode_info; |
int index = GetIndexIntoMasterTable(DATA, AnalogTV_Info); |
uint16_t data_offset; |
uint8_t frev, crev; |
struct _ATOM_ANALOG_TV_INFO *tv_info; |
enum radeon_tv_std tv_std = TV_STD_NTSC; |
atom_parse_data_header(mode_info->atom_context, index, NULL, &frev, &crev, &data_offset); |
tv_info = (struct _ATOM_ANALOG_TV_INFO *)(mode_info->atom_context->bios + data_offset); |
switch (tv_info->ucTV_BootUpDefaultStandard) { |
case ATOM_TV_NTSC: |
tv_std = TV_STD_NTSC; |
DRM_INFO("Default TV standard: NTSC\n"); |
break; |
case ATOM_TV_NTSCJ: |
tv_std = TV_STD_NTSC_J; |
DRM_INFO("Default TV standard: NTSC-J\n"); |
break; |
case ATOM_TV_PAL: |
tv_std = TV_STD_PAL; |
DRM_INFO("Default TV standard: PAL\n"); |
break; |
case ATOM_TV_PALM: |
tv_std = TV_STD_PAL_M; |
DRM_INFO("Default TV standard: PAL-M\n"); |
break; |
case ATOM_TV_PALN: |
tv_std = TV_STD_PAL_N; |
DRM_INFO("Default TV standard: PAL-N\n"); |
break; |
case ATOM_TV_PALCN: |
tv_std = TV_STD_PAL_CN; |
DRM_INFO("Default TV standard: PAL-CN\n"); |
break; |
case ATOM_TV_PAL60: |
tv_std = TV_STD_PAL_60; |
DRM_INFO("Default TV standard: PAL-60\n"); |
break; |
case ATOM_TV_SECAM: |
tv_std = TV_STD_SECAM; |
DRM_INFO("Default TV standard: SECAM\n"); |
break; |
default: |
tv_std = TV_STD_NTSC; |
DRM_INFO("Unknown TV standard; defaulting to NTSC\n"); |
break; |
} |
return tv_std; |
} |
struct radeon_encoder_tv_dac * |
radeon_atombios_get_tv_dac_info(struct radeon_encoder *encoder) |
{ |
1362,7 → 1269,6 |
dac = dac_info->ucDAC2_NTSC_DAC_Adjustment; |
tv_dac->ntsc_tvdac_adj = (bg << 16) | (dac << 20); |
tv_dac->tv_std = radeon_atombios_get_tv_info(rdev); |
} |
return tv_dac; |
} |
/drivers/video/drm/radeon/radeon_combios.c |
---|
595,48 → 595,6 |
return false; |
} |
bool radeon_combios_sideport_present(struct radeon_device *rdev) |
{ |
struct drm_device *dev = rdev->ddev; |
u16 igp_info; |
igp_info = combios_get_table_offset(dev, COMBIOS_INTEGRATED_SYSTEM_INFO_TABLE); |
if (igp_info) { |
if (RBIOS16(igp_info + 0x4)) |
return true; |
} |
return false; |
} |
static const uint32_t default_primarydac_adj[CHIP_LAST] = { |
0x00000808, /* r100 */ |
0x00000808, /* rv100 */ |
0x00000808, /* rs100 */ |
0x00000808, /* rv200 */ |
0x00000808, /* rs200 */ |
0x00000808, /* r200 */ |
0x00000808, /* rv250 */ |
0x00000000, /* rs300 */ |
0x00000808, /* rv280 */ |
0x00000808, /* r300 */ |
0x00000808, /* r350 */ |
0x00000808, /* rv350 */ |
0x00000808, /* rv380 */ |
0x00000808, /* r420 */ |
0x00000808, /* r423 */ |
0x00000808, /* rv410 */ |
0x00000000, /* rs400 */ |
0x00000000, /* rs480 */ |
}; |
static void radeon_legacy_get_primary_dac_info_from_table(struct radeon_device *rdev, |
struct radeon_encoder_primary_dac *p_dac) |
{ |
p_dac->ps2_pdac_adj = default_primarydac_adj[rdev->family]; |
return; |
} |
struct radeon_encoder_primary_dac *radeon_combios_get_primary_dac_info(struct |
radeon_encoder |
*encoder) |
646,20 → 604,20 |
uint16_t dac_info; |
uint8_t rev, bg, dac; |
struct radeon_encoder_primary_dac *p_dac = NULL; |
int found = 0; |
p_dac = kzalloc(sizeof(struct radeon_encoder_primary_dac), |
if (rdev->bios == NULL) |
return NULL; |
/* check CRT table */ |
dac_info = combios_get_table_offset(dev, COMBIOS_CRT_INFO_TABLE); |
if (dac_info) { |
p_dac = |
kzalloc(sizeof(struct radeon_encoder_primary_dac), |
GFP_KERNEL); |
if (!p_dac) |
return NULL; |
if (rdev->bios == NULL) |
goto out; |
/* check CRT table */ |
dac_info = combios_get_table_offset(dev, COMBIOS_CRT_INFO_TABLE); |
if (dac_info) { |
rev = RBIOS8(dac_info) & 0x3; |
if (rev < 2) { |
bg = RBIOS8(dac_info + 0x2) & 0xf; |
670,26 → 628,20 |
dac = RBIOS8(dac_info + 0x3) & 0xf; |
p_dac->ps2_pdac_adj = (bg << 8) | (dac); |
} |
found = 1; |
} |
out: |
if (!found) /* fallback to defaults */ |
radeon_legacy_get_primary_dac_info_from_table(rdev, p_dac); |
return p_dac; |
} |
enum radeon_tv_std |
radeon_combios_get_tv_info(struct radeon_device *rdev) |
static enum radeon_tv_std |
radeon_combios_get_tv_info(struct radeon_encoder *encoder) |
{ |
struct drm_device *dev = rdev->ddev; |
struct drm_device *dev = encoder->base.dev; |
struct radeon_device *rdev = dev->dev_private; |
uint16_t tv_info; |
enum radeon_tv_std tv_std = TV_STD_NTSC; |
if (rdev->bios == NULL) |
return tv_std; |
tv_info = combios_get_table_offset(dev, COMBIOS_TV_INFO_TABLE); |
if (tv_info) { |
if (RBIOS8(tv_info + 6) == 'T') { |
827,7 → 779,7 |
tv_dac->ntsc_tvdac_adj = (bg << 16) | (dac << 20); |
found = 1; |
} |
tv_dac->tv_std = radeon_combios_get_tv_info(rdev); |
tv_dac->tv_std = radeon_combios_get_tv_info(encoder); |
} |
if (!found) { |
/* then check CRT table */ |
971,7 → 923,8 |
lvds->native_mode.vdisplay); |
lvds->panel_vcc_delay = RBIOS16(lcd_info + 0x2c); |
lvds->panel_vcc_delay = min_t(u16, lvds->panel_vcc_delay, 2000); |
if (lvds->panel_vcc_delay > 2000 || lvds->panel_vcc_delay < 0) |
lvds->panel_vcc_delay = 2000; |
lvds->panel_pwr_delay = RBIOS8(lcd_info + 0x24); |
lvds->panel_digon_delay = RBIOS16(lcd_info + 0x38) & 0xf; |
/drivers/video/drm/radeon/radeon_device.c |
---|
46,19 → 46,15 |
int radeon_connector_table = 0; |
int radeon_tv = 0; |
int radeon_modeset = 1; |
int radeon_new_pll = 1; |
int radeon_vram_limit = 0; |
int radeon_audio = 0; |
void parse_cmdline(char *cmdline, mode_t *mode, char *log, int *kms); |
int init_display(struct radeon_device *rdev, mode_t *mode); |
int init_display_kms(struct radeon_device *rdev, mode_t *mode); |
void parse_cmdline(char *cmdline, videomode_t *mode, char *log, int *kms); |
int init_display(struct radeon_device *rdev, videomode_t *mode); |
int init_display_kms(struct radeon_device *rdev, videomode_t *mode); |
int get_modes(mode_t *mode, int *count); |
int set_user_mode(mode_t *mode); |
int get_modes(videomode_t *mode, int *count); |
int set_user_mode(videomode_t *mode); |
/* Legacy VGA regions */ |
#define VGA_RSRC_NONE 0x00 |
#define VGA_RSRC_LEGACY_IO 0x01 |
75,11 → 71,16 |
*/ |
void radeon_surface_init(struct radeon_device *rdev) |
{ |
ENTER(); |
/* FIXME: check this out */ |
if (rdev->family < CHIP_R600) { |
int i; |
for (i = 0; i < RADEON_GEM_MAX_SURFACES; i++) { |
if (rdev->surface_regs[i].bo) |
radeon_bo_get_surface_reg(rdev->surface_regs[i].bo); |
else |
radeon_clear_surface_reg(rdev, i); |
} |
/* enable surfaces */ |
420,12 → 421,6 |
/* FIXME: not supported yet */ |
return -EINVAL; |
} |
if (rdev->flags & RADEON_IS_IGP) { |
rdev->asic->get_memory_clock = NULL; |
rdev->asic->set_memory_clock = NULL; |
} |
return 0; |
} |
572,75 → 567,11 |
rdev->asic->gart_tlb_flush = &r100_pci_gart_tlb_flush; |
rdev->asic->gart_set_page = &r100_pci_gart_set_page; |
} |
rdev->mc.gtt_size = radeon_gart_size * 1024 * 1024; |
} |
void radeon_check_arguments(struct radeon_device *rdev) |
{ |
/* vramlimit must be a power of two */ |
switch (radeon_vram_limit) { |
case 0: |
case 4: |
case 8: |
case 16: |
case 32: |
case 64: |
case 128: |
case 256: |
case 512: |
case 1024: |
case 2048: |
case 4096: |
break; |
default: |
dev_warn(rdev->dev, "vram limit (%d) must be a power of 2\n", |
radeon_vram_limit); |
radeon_vram_limit = 0; |
break; |
} |
radeon_vram_limit = radeon_vram_limit << 20; |
/* gtt size must be power of two and greater or equal to 32M */ |
switch (radeon_gart_size) { |
case 4: |
case 8: |
case 16: |
dev_warn(rdev->dev, "gart size (%d) too small forcing to 512M\n", |
radeon_gart_size); |
radeon_gart_size = 512; |
break; |
case 32: |
case 64: |
case 128: |
case 256: |
case 512: |
case 1024: |
case 2048: |
case 4096: |
break; |
default: |
dev_warn(rdev->dev, "gart size (%d) must be a power of 2\n", |
radeon_gart_size); |
radeon_gart_size = 512; |
break; |
} |
rdev->mc.gtt_size = radeon_gart_size * 1024 * 1024; |
/* AGP mode can only be -1, 1, 2, 4, 8 */ |
switch (radeon_agpmode) { |
case -1: |
case 0: |
case 1: |
case 2: |
case 4: |
case 8: |
break; |
default: |
dev_warn(rdev->dev, "invalid AGP mode %d (valid mode: " |
"-1, 0, 1, 2, 4, 8)\n", radeon_agpmode); |
radeon_agpmode = 0; |
break; |
} |
} |
/* |
* Radeon device. |
*/ |
int radeon_device_init(struct radeon_device *rdev, |
struct drm_device *ddev, |
struct pci_dev *pdev, |
669,9 → 600,9 |
/* Set asic functions */ |
r = radeon_asic_init(rdev); |
if (r) |
if (r) { |
return r; |
radeon_check_arguments(rdev); |
} |
if (rdev->flags & RADEON_IS_AGP && radeon_agpmode == -1) { |
radeon_agp_disable(rdev); |
792,7 → 723,7 |
return 0; |
} |
videomode_t usermode; |
mode_t usermode; |
int drm_get_dev(struct pci_dev *pdev, const struct pci_device_id *ent) |
936,9 → 867,9 |
if( radeon_modeset && |
(outp != NULL) && (io->out_size == 4) && |
(io->inp_size == *outp * sizeof(videomode_t)) ) |
(io->inp_size == *outp * sizeof(mode_t)) ) |
{ |
retval = get_modes((videomode_t*)inp, outp); |
retval = get_modes((mode_t*)inp, outp); |
}; |
break; |
948,9 → 879,9 |
if( radeon_modeset && |
(inp != NULL) && |
(io->inp_size == sizeof(videomode_t)) ) |
(io->inp_size == sizeof(mode_t)) ) |
{ |
retval = set_user_mode((videomode_t*)inp); |
retval = set_user_mode((mode_t*)inp); |
}; |
break; |
}; |
959,7 → 890,7 |
} |
static char log[256]; |
static pci_dev_t device; |
static dev_t device; |
u32_t drvEntry(int action, char *cmdline) |
{ |
987,7 → 918,7 |
return 0; |
}; |
} |
dbgprintf("Radeon RC9 cmdline %s\n", cmdline); |
dbgprintf("Radeon RC09 cmdline %s\n", cmdline); |
enum_pci_devices(); |
/drivers/video/drm/radeon/radeon_fence.c |
---|
140,15 → 140,16 |
bool radeon_fence_signaled(struct radeon_fence *fence) |
{ |
struct radeon_device *rdev = fence->rdev; |
unsigned long irq_flags; |
bool signaled = false; |
if (!fence) |
if (rdev->gpu_lockup) { |
return true; |
if (fence->rdev->gpu_lockup) |
} |
if (fence == NULL) { |
return true; |
} |
write_lock_irqsave(&fence->rdev->fence_drv.lock, irq_flags); |
signaled = fence->signaled; |
/* if we are shuting down report all fence as signaled */ |
323,7 → 324,7 |
write_lock_irqsave(&rdev->fence_drv.lock, irq_flags); |
r = radeon_scratch_get(rdev, &rdev->fence_drv.scratch_reg); |
if (r) { |
dev_err(rdev->dev, "fence failed to get scratch register\n"); |
DRM_ERROR("Fence failed to get a scratch register."); |
write_unlock_irqrestore(&rdev->fence_drv.lock, irq_flags); |
return r; |
} |
334,10 → 335,9 |
INIT_LIST_HEAD(&rdev->fence_drv.signaled); |
rdev->fence_drv.count_timeout = 0; |
init_waitqueue_head(&rdev->fence_drv.queue); |
rdev->fence_drv.initialized = true; |
write_unlock_irqrestore(&rdev->fence_drv.lock, irq_flags); |
if (radeon_debugfs_fence_init(rdev)) { |
dev_err(rdev->dev, "fence debugfs file creation failed\n"); |
DRM_ERROR("Failed to register debugfs file for fence !\n"); |
} |
return 0; |
} |
346,13 → 346,11 |
{ |
unsigned long irq_flags; |
if (!rdev->fence_drv.initialized) |
return; |
wake_up_all(&rdev->fence_drv.queue); |
write_lock_irqsave(&rdev->fence_drv.lock, irq_flags); |
radeon_scratch_free(rdev, rdev->fence_drv.scratch_reg); |
write_unlock_irqrestore(&rdev->fence_drv.lock, irq_flags); |
rdev->fence_drv.initialized = false; |
DRM_INFO("radeon: fence finalized\n"); |
} |
/drivers/video/drm/radeon/radeon_i2c.c |
---|
216,7 → 216,7 |
return NULL; |
i2c->rec = *rec; |
// i2c->adapter.owner = THIS_MODULE; |
i2c->adapter.owner = THIS_MODULE; |
i2c->dev = dev; |
i2c->adapter.algo_data = &i2c->algo.dp; |
i2c->algo.dp.aux_ch = radeon_dp_i2c_aux_ch; |
/drivers/video/drm/radeon/radeon_legacy_crtc.c |
---|
43,7 → 43,8 |
} |
static void radeon_legacy_rmx_mode_set(struct drm_crtc *crtc, |
struct drm_display_mode *mode) |
struct drm_display_mode *mode, |
struct drm_display_mode *adjusted_mode) |
{ |
struct drm_device *dev = crtc->dev; |
struct radeon_device *rdev = dev->dev_private; |
321,11 → 322,13 |
RADEON_CRTC_DISP_REQ_EN_B)); |
WREG32_P(RADEON_CRTC_EXT_CNTL, 0, ~mask); |
} |
// drm_vblank_post_modeset(dev, radeon_crtc->crtc_id); |
radeon_crtc_load_lut(crtc); |
break; |
case DRM_MODE_DPMS_STANDBY: |
case DRM_MODE_DPMS_SUSPEND: |
case DRM_MODE_DPMS_OFF: |
// drm_vblank_pre_modeset(dev, radeon_crtc->crtc_id); |
if (radeon_crtc->crtc_id) |
WREG32_P(RADEON_CRTC2_GEN_CNTL, mask, ~(RADEON_CRTC2_EN | mask)); |
else { |
337,6 → 340,69 |
} |
} |
/* properly set crtc bpp when using atombios */ |
void radeon_legacy_atom_set_surface(struct drm_crtc *crtc) |
{ |
struct drm_device *dev = crtc->dev; |
struct radeon_device *rdev = dev->dev_private; |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
int format; |
uint32_t crtc_gen_cntl; |
uint32_t disp_merge_cntl; |
uint32_t crtc_pitch; |
switch (crtc->fb->bits_per_pixel) { |
case 8: |
format = 2; |
break; |
case 15: /* 555 */ |
format = 3; |
break; |
case 16: /* 565 */ |
format = 4; |
break; |
case 24: /* RGB */ |
format = 5; |
break; |
case 32: /* xRGB */ |
format = 6; |
break; |
default: |
return; |
} |
crtc_pitch = ((((crtc->fb->pitch / (crtc->fb->bits_per_pixel / 8)) * crtc->fb->bits_per_pixel) + |
((crtc->fb->bits_per_pixel * 8) - 1)) / |
(crtc->fb->bits_per_pixel * 8)); |
crtc_pitch |= crtc_pitch << 16; |
WREG32(RADEON_CRTC_PITCH + radeon_crtc->crtc_offset, crtc_pitch); |
switch (radeon_crtc->crtc_id) { |
case 0: |
disp_merge_cntl = RREG32(RADEON_DISP_MERGE_CNTL); |
disp_merge_cntl &= ~RADEON_DISP_RGB_OFFSET_EN; |
WREG32(RADEON_DISP_MERGE_CNTL, disp_merge_cntl); |
crtc_gen_cntl = RREG32(RADEON_CRTC_GEN_CNTL) & 0xfffff0ff; |
crtc_gen_cntl |= (format << 8); |
crtc_gen_cntl |= RADEON_CRTC_EXT_DISP_EN; |
WREG32(RADEON_CRTC_GEN_CNTL, crtc_gen_cntl); |
break; |
case 1: |
disp_merge_cntl = RREG32(RADEON_DISP2_MERGE_CNTL); |
disp_merge_cntl &= ~RADEON_DISP2_RGB_OFFSET_EN; |
WREG32(RADEON_DISP2_MERGE_CNTL, disp_merge_cntl); |
crtc_gen_cntl = RREG32(RADEON_CRTC2_GEN_CNTL) & 0xfffff0ff; |
crtc_gen_cntl |= (format << 8); |
WREG32(RADEON_CRTC2_GEN_CNTL, crtc_gen_cntl); |
WREG32(RADEON_FP_H2_SYNC_STRT_WID, RREG32(RADEON_CRTC2_H_SYNC_STRT_WID)); |
WREG32(RADEON_FP_V2_SYNC_STRT_WID, RREG32(RADEON_CRTC2_V_SYNC_STRT_WID)); |
break; |
} |
} |
int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y, |
struct drm_framebuffer *old_fb) |
{ |
690,6 → 756,7 |
uint32_t post_divider = 0; |
uint32_t freq = 0; |
uint8_t pll_gain; |
int pll_flags = RADEON_PLL_LEGACY; |
bool use_bios_divs = false; |
/* PLL registers */ |
uint32_t pll_ref_div = 0; |
723,12 → 790,10 |
else |
pll = &rdev->clock.p1pll; |
pll->flags = RADEON_PLL_LEGACY; |
if (mode->clock > 200000) /* range limits??? */ |
pll->flags |= RADEON_PLL_PREFER_HIGH_FB_DIV; |
pll_flags |= RADEON_PLL_PREFER_HIGH_FB_DIV; |
else |
pll->flags |= RADEON_PLL_PREFER_LOW_REF_DIV; |
pll_flags |= RADEON_PLL_PREFER_LOW_REF_DIV; |
list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) { |
if (encoder->crtc == crtc) { |
740,7 → 805,7 |
} |
if (encoder->encoder_type != DRM_MODE_ENCODER_DAC) |
pll->flags |= RADEON_PLL_NO_ODD_POST_DIV; |
pll_flags |= RADEON_PLL_NO_ODD_POST_DIV; |
if (encoder->encoder_type == DRM_MODE_ENCODER_LVDS) { |
if (!rdev->is_atom_bios) { |
struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); |
755,7 → 820,7 |
} |
} |
} |
pll->flags |= RADEON_PLL_USE_REF_DIV; |
pll_flags |= RADEON_PLL_USE_REF_DIV; |
} |
} |
} |
765,7 → 830,8 |
if (!use_bios_divs) { |
radeon_compute_pll(pll, mode->clock, |
&freq, &feedback_div, &frac_fb_div, |
&reference_div, &post_divider); |
&reference_div, &post_divider, |
pll_flags); |
for (post_div = &post_divs[0]; post_div->divider; ++post_div) { |
if (post_div->divider == post_divider) |
993,7 → 1059,7 |
radeon_set_pll(crtc, adjusted_mode); |
radeon_overscan_setup(crtc, adjusted_mode); |
if (radeon_crtc->crtc_id == 0) { |
radeon_legacy_rmx_mode_set(crtc, adjusted_mode); |
radeon_legacy_rmx_mode_set(crtc, mode, adjusted_mode); |
} else { |
if (radeon_crtc->rmx_type != RMX_OFF) { |
/* FIXME: only first crtc has rmx what should we |
/drivers/video/drm/radeon/radeon_mode.h |
---|
46,6 → 46,32 |
#define to_radeon_encoder(x) container_of(x, struct radeon_encoder, base) |
#define to_radeon_framebuffer(x) container_of(x, struct radeon_framebuffer, base) |
enum radeon_connector_type { |
CONNECTOR_NONE, |
CONNECTOR_VGA, |
CONNECTOR_DVI_I, |
CONNECTOR_DVI_D, |
CONNECTOR_DVI_A, |
CONNECTOR_STV, |
CONNECTOR_CTV, |
CONNECTOR_LVDS, |
CONNECTOR_DIGITAL, |
CONNECTOR_SCART, |
CONNECTOR_HDMI_TYPE_A, |
CONNECTOR_HDMI_TYPE_B, |
CONNECTOR_0XC, |
CONNECTOR_0XD, |
CONNECTOR_DIN, |
CONNECTOR_DISPLAY_PORT, |
CONNECTOR_UNSUPPORTED |
}; |
enum radeon_dvi_type { |
DVI_AUTO, |
DVI_DIGITAL, |
DVI_ANALOG |
}; |
enum radeon_rmx_type { |
RMX_OFF, |
RMX_FULL, |
62,7 → 88,6 |
TV_STD_SCART_PAL, |
TV_STD_SECAM, |
TV_STD_PAL_CN, |
TV_STD_PAL_N, |
}; |
/* radeon gpio-based i2c |
125,24 → 150,16 |
#define RADEON_PLL_PREFER_HIGH_POST_DIV (1 << 9) |
#define RADEON_PLL_USE_FRAC_FB_DIV (1 << 10) |
#define RADEON_PLL_PREFER_CLOSEST_LOWER (1 << 11) |
#define RADEON_PLL_USE_POST_DIV (1 << 12) |
struct radeon_pll { |
/* reference frequency */ |
uint32_t reference_freq; |
/* fixed dividers */ |
uint32_t reference_div; |
uint32_t post_div; |
/* pll in/out limits */ |
uint16_t reference_freq; |
uint16_t reference_div; |
uint32_t pll_in_min; |
uint32_t pll_in_max; |
uint32_t pll_out_min; |
uint32_t pll_out_max; |
uint32_t best_vco; |
uint16_t xclk; |
/* divider limits */ |
uint32_t min_ref_div; |
uint32_t max_ref_div; |
uint32_t min_post_div; |
151,12 → 168,7 |
uint32_t max_feedback_div; |
uint32_t min_frac_feedback_div; |
uint32_t max_frac_feedback_div; |
/* flags for the current clock */ |
uint32_t flags; |
/* pll id */ |
uint32_t id; |
uint32_t best_vco; |
}; |
struct radeon_i2c_chan { |
299,7 → 311,7 |
struct radeon_encoder_atom_dig { |
/* atom dig */ |
bool coherent_mode; |
int dig_encoder; /* -1 disabled, 0 DIGA, 1 DIGB */ |
int dig_block; |
/* atom lvds */ |
uint32_t lvds_misc; |
uint16_t panel_pwr_delay; |
322,9 → 334,6 |
enum radeon_rmx_type rmx_type; |
struct drm_display_mode native_mode; |
void *enc_priv; |
int hdmi_offset; |
int hdmi_audio_workaround; |
int hdmi_buffer_status; |
}; |
struct radeon_connector_atom_dig { |
383,11 → 392,6 |
struct drm_gem_object *obj; |
}; |
extern enum radeon_tv_std |
radeon_combios_get_tv_info(struct radeon_device *rdev); |
extern enum radeon_tv_std |
radeon_atombios_get_tv_info(struct radeon_device *rdev); |
extern void radeon_connector_hotplug(struct drm_connector *connector); |
extern bool radeon_dp_needs_link_train(struct radeon_connector *radeon_connector); |
extern int radeon_dp_mode_valid_helper(struct radeon_connector *radeon_connector, |
430,7 → 434,8 |
uint32_t *fb_div_p, |
uint32_t *frac_fb_div_p, |
uint32_t *ref_div_p, |
uint32_t *post_div_p); |
uint32_t *post_div_p, |
int flags); |
extern void radeon_compute_pll_avivo(struct radeon_pll *pll, |
uint64_t freq, |
438,7 → 443,8 |
uint32_t *fb_div_p, |
uint32_t *frac_fb_div_p, |
uint32_t *ref_div_p, |
uint32_t *post_div_p); |
uint32_t *post_div_p, |
int flags); |
extern void radeon_setup_encoder_clones(struct drm_device *dev); |
464,6 → 470,7 |
extern int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y, |
struct drm_framebuffer *old_fb); |
extern void radeon_legacy_atom_set_surface(struct drm_crtc *crtc); |
extern int radeon_crtc_cursor_set(struct drm_crtc *crtc, |
struct drm_file *file_priv, |
/drivers/video/drm/radeon/radeon_object.h |
---|
59,10 → 59,24 |
* |
* Returns: |
* -EBUSY: buffer is busy and @no_wait is true |
* -ERESTARTSYS: A wait for the buffer to become unreserved was interrupted by |
* -ERESTART: A wait for the buffer to become unreserved was interrupted by |
* a signal. Release all buffer reservations and return to user-space. |
*/ |
static inline int radeon_bo_reserve(struct radeon_bo *bo, bool no_wait) |
{ |
int r; |
retry: |
r = ttm_bo_reserve(&bo->tbo, true, no_wait, false, 0); |
if (unlikely(r != 0)) { |
if (r == -ERESTART) |
goto retry; |
dev_err(bo->rdev->dev, "%p reserve failed\n", bo); |
return r; |
} |
return 0; |
} |
static inline void radeon_bo_unreserve(struct radeon_bo *bo) |
{ |
ttm_bo_unreserve(&bo->tbo); |
111,9 → 125,11 |
{ |
int r; |
retry: |
r = ttm_bo_reserve(&bo->tbo, true, no_wait, false, 0); |
if (unlikely(r != 0)) { |
if (r != -ERESTARTSYS) |
if (r == -ERESTART) |
goto retry; |
dev_err(bo->rdev->dev, "%p reserve failed for wait\n", bo); |
return r; |
} |
124,6 → 140,8 |
r = ttm_bo_wait(&bo->tbo, true, true, no_wait); |
spin_unlock(&bo->tbo.lock); |
ttm_bo_unreserve(&bo->tbo); |
if (unlikely(r == -ERESTART)) |
goto retry; |
return r; |
} |
/drivers/video/drm/radeon/radeon_pm.c |
---|
44,11 → 44,8 |
struct drm_device *dev = node->minor->dev; |
struct radeon_device *rdev = dev->dev_private; |
seq_printf(m, "default engine clock: %u0 kHz\n", rdev->clock.default_sclk); |
seq_printf(m, "current engine clock: %u0 kHz\n", radeon_get_engine_clock(rdev)); |
seq_printf(m, "default memory clock: %u0 kHz\n", rdev->clock.default_mclk); |
if (rdev->asic->get_memory_clock) |
seq_printf(m, "current memory clock: %u0 kHz\n", radeon_get_memory_clock(rdev)); |
seq_printf(m, "engine clock: %u0 kHz\n", radeon_get_engine_clock(rdev)); |
seq_printf(m, "memory clock: %u0 kHz\n", radeon_get_memory_clock(rdev)); |
return 0; |
} |
/drivers/video/drm/radeon/display.h |
---|
20,7 → 20,7 |
uint32_t hot_y; |
struct list_head list; |
struct radeon_bo *robj; |
struct radeon_object *robj; |
}cursor_t; |
#define CURSOR_WIDTH 64 |
/drivers/video/drm/radeon/makefile |
---|
1,30 → 1,23 |
CC = gcc |
FASM = e:/fasm/fasm.exe |
CFLAGS = -c -O2 -fomit-frame-pointer -fno-builtin-printf |
LDFLAGS = -nostdlib -shared -s -Map atikms.map --image-base 0 --file-alignment 512 --section-alignment 4096 |
DEFINES = -D__KERNEL__ -DCONFIG_X86_32 |
DRM_TOPDIR = $(CURDIR)/.. |
DRM_INCLUDES = $(DRM_TOPDIR)/includes |
INCLUDES = -I$(DRM_INCLUDES) -I$(DRM_INCLUDES)/drm \ |
-I$(DRM_INCLUDES)/linux -I$(DRM_INCLUDES)/asm |
CFLAGS = -c -O2 $(INCLUDES) $(DEFINES) -march=i686 -fomit-frame-pointer -fno-builtin-printf |
LIBPATH:= . |
LIBS:= -ldrv -lcore |
LDFLAGS = -nostdlib -shared -s -Map atikms.map --image-base 0\ |
--file-alignment 512 --section-alignment 4096 |
NAME:= atikms |
INCLUDES = -I$(DRM_INCLUDES) -I$(DRM_INCLUDES)/linux -I$(DRM_INCLUDES)/drm |
NAME:= atikms |
HFILES:= $(DRM_INCLUDES)/linux/types.h \ |
$(DRM_INCLUDES)/linux/list.h \ |
$(DRM_INCLUDES)/linux/pci.h \ |
$(DRM_INCLUDES)/pci.h \ |
$(DRM_INCLUDES)/drm/drm.h \ |
$(DRM_INCLUDES)/drm/drmP.h \ |
$(DRM_INCLUDES)/drm/drm_edid.h \ |
43,11 → 36,10 |
$(DRM_TOPDIR)/drm_crtc.c \ |
$(DRM_TOPDIR)/drm_crtc_helper.c \ |
$(DRM_TOPDIR)/drm_fb_helper.c \ |
$(DRM_TOPDIR)/drm_dp_i2c_helper.c \ |
$(DRM_TOPDIR)/i2c/i2c-core.c \ |
$(DRM_TOPDIR)/i2c/i2c-algo-bit.c \ |
$(DRM_TOPDIR)/idr.c \ |
$(DRM_TOPDIR)/list_sort.c \ |
radeon_gem.c \ |
radeon_device.c \ |
radeon_clocks.c \ |
radeon_i2c.c \ |
55,7 → 47,6 |
radeon_atombios.c \ |
radeon_agp.c \ |
atombios_crtc.c \ |
atombios_dp.c \ |
radeon_encoders.c \ |
radeon_connectors.c \ |
radeon_bios.c \ |
64,10 → 55,9 |
radeon_legacy_encoders.c \ |
radeon_legacy_tv.c \ |
radeon_display.c \ |
radeon_object.c \ |
radeon_gart.c \ |
radeon_ring.c \ |
radeon_object_kos.c \ |
radeon_gem.c \ |
r100.c \ |
r200.c \ |
r300.c \ |
75,8 → 65,6 |
rv515.c \ |
r520.c \ |
r600.c \ |
r600_audio.c \ |
r600_hdmi.c \ |
rs400.c \ |
rs600.c \ |
rs690.c \ |
104,7 → 92,7 |
%.o : %.c $(HFILES) Makefile |
$(CC) $(CFLAGS) $(DEFINES) -o $@ $< |
$(CC) $(CFLAGS) $(DEFINES) $(INCLUDES) -o $@ -c $< |
%.o : %.S $(HFILES) Makefile |
as -o $@ $< |
/drivers/video/drm/radeon/radeon_gart.c |
---|
78,9 → 78,11 |
int r; |
if (rdev->gart.table.vram.robj == NULL) { |
r = radeon_bo_create(rdev, NULL, rdev->gart.table_size, |
true, RADEON_GEM_DOMAIN_VRAM, |
&rdev->gart.table.vram.robj); |
r = radeon_object_create(rdev, NULL, |
rdev->gart.table_size, |
true, |
RADEON_GEM_DOMAIN_VRAM, |
false, &rdev->gart.table.vram.robj); |
if (r) { |
return r; |
} |
93,42 → 95,48 |
uint64_t gpu_addr; |
int r; |
r = radeon_bo_reserve(rdev->gart.table.vram.robj, false); |
if (unlikely(r != 0)) |
return r; |
r = radeon_bo_pin(rdev->gart.table.vram.robj, |
r = radeon_object_pin(rdev->gart.table.vram.robj, |
RADEON_GEM_DOMAIN_VRAM, &gpu_addr); |
if (r) { |
radeon_bo_unreserve(rdev->gart.table.vram.robj); |
// radeon_object_unref(&rdev->gart.table.vram.robj); |
return r; |
} |
r = radeon_bo_kmap(rdev->gart.table.vram.robj, |
r = radeon_object_kmap(rdev->gart.table.vram.robj, |
(void **)&rdev->gart.table.vram.ptr); |
if (r) |
radeon_bo_unpin(rdev->gart.table.vram.robj); |
radeon_bo_unreserve(rdev->gart.table.vram.robj); |
rdev->gart.table_addr = gpu_addr; |
if (r) { |
// radeon_object_unpin(rdev->gart.table.vram.robj); |
// radeon_object_unref(&rdev->gart.table.vram.robj); |
DRM_ERROR("radeon: failed to map gart vram table.\n"); |
return r; |
} |
rdev->gart.table_addr = gpu_addr; |
dbgprintf("alloc gart vram: gpu_base %x lin_addr %x\n", |
rdev->gart.table_addr, rdev->gart.table.vram.ptr); |
// gpu_addr = 0x800000; |
// u32_t pci_addr = rdev->mc.aper_base + gpu_addr; |
// rdev->gart.table.vram.ptr = (void*)MapIoMem(pci_addr, rdev->gart.table_size, PG_SW); |
// dbgprintf("alloc gart vram:\n gpu_base %x pci_base %x lin_addr %x", |
// gpu_addr, pci_addr, rdev->gart.table.vram.ptr); |
return 0; |
} |
void radeon_gart_table_vram_free(struct radeon_device *rdev) |
{ |
int r; |
if (rdev->gart.table.vram.robj == NULL) { |
return; |
} |
r = radeon_bo_reserve(rdev->gart.table.vram.robj, false); |
if (likely(r == 0)) { |
radeon_bo_kunmap(rdev->gart.table.vram.robj); |
radeon_bo_unpin(rdev->gart.table.vram.robj); |
radeon_bo_unreserve(rdev->gart.table.vram.robj); |
// radeon_object_kunmap(rdev->gart.table.vram.robj); |
// radeon_object_unpin(rdev->gart.table.vram.robj); |
// radeon_object_unref(&rdev->gart.table.vram.robj); |
} |
radeon_bo_unref(&rdev->gart.table.vram.robj); |
} |
144,7 → 152,7 |
int i, j; |
if (!rdev->gart.ready) { |
WARN(1, "trying to unbind memory to unitialized GART !\n"); |
// WARN(1, "trying to unbind memory to unitialized GART !\n"); |
return; |
} |
t = offset / RADEON_GPU_PAGE_SIZE; |
226,13 → 234,13 |
rdev->gart.pages = kzalloc(sizeof(void *) * rdev->gart.num_cpu_pages, |
GFP_KERNEL); |
if (rdev->gart.pages == NULL) { |
radeon_gart_fini(rdev); |
// radeon_gart_fini(rdev); |
return -ENOMEM; |
} |
rdev->gart.pages_addr = kzalloc(sizeof(dma_addr_t) * |
rdev->gart.pages_addr = kzalloc(sizeof(u32_t) * |
rdev->gart.num_cpu_pages, GFP_KERNEL); |
if (rdev->gart.pages_addr == NULL) { |
radeon_gart_fini(rdev); |
// radeon_gart_fini(rdev); |
return -ENOMEM; |
} |
return 0; |
/drivers/video/drm/radeon/radeon_display.c |
---|
234,7 → 234,7 |
"INTERNAL_UNIPHY2", |
}; |
static const char *connector_names[15] = { |
static const char *connector_names[13] = { |
"Unknown", |
"VGA", |
"DVI-I", |
248,20 → 248,8 |
"DisplayPort", |
"HDMI-A", |
"HDMI-B", |
"TV", |
"eDP", |
}; |
static const char *hpd_names[7] = { |
"NONE", |
"HPD1", |
"HPD2", |
"HPD3", |
"HPD4", |
"HPD5", |
"HPD6", |
}; |
static void radeon_print_display_setup(struct drm_device *dev) |
{ |
struct drm_connector *connector; |
276,27 → 264,16 |
radeon_connector = to_radeon_connector(connector); |
DRM_INFO("Connector %d:\n", i); |
DRM_INFO(" %s\n", connector_names[connector->connector_type]); |
if (radeon_connector->hpd.hpd != RADEON_HPD_NONE) |
DRM_INFO(" %s\n", hpd_names[radeon_connector->hpd.hpd]); |
if (radeon_connector->ddc_bus) { |
if (radeon_connector->ddc_bus) |
DRM_INFO(" DDC: 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x\n", |
radeon_connector->ddc_bus->rec.mask_clk_reg, |
radeon_connector->ddc_bus->rec.mask_data_reg, |
radeon_connector->ddc_bus->rec.a_clk_reg, |
radeon_connector->ddc_bus->rec.a_data_reg, |
radeon_connector->ddc_bus->rec.en_clk_reg, |
radeon_connector->ddc_bus->rec.en_data_reg, |
radeon_connector->ddc_bus->rec.y_clk_reg, |
radeon_connector->ddc_bus->rec.y_data_reg); |
} else { |
if (connector->connector_type == DRM_MODE_CONNECTOR_VGA || |
connector->connector_type == DRM_MODE_CONNECTOR_DVII || |
connector->connector_type == DRM_MODE_CONNECTOR_DVID || |
connector->connector_type == DRM_MODE_CONNECTOR_DVIA || |
connector->connector_type == DRM_MODE_CONNECTOR_HDMIA || |
connector->connector_type == DRM_MODE_CONNECTOR_HDMIB) |
DRM_INFO(" DDC: no ddc bus - possible BIOS bug - please report to xorg-driver-ati@lists.x.org\n"); |
} |
radeon_connector->ddc_bus->rec.put_clk_reg, |
radeon_connector->ddc_bus->rec.put_data_reg, |
radeon_connector->ddc_bus->rec.get_clk_reg, |
radeon_connector->ddc_bus->rec.get_data_reg); |
DRM_INFO(" Encoders:\n"); |
list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) { |
radeon_encoder = to_radeon_encoder(encoder); |
340,17 → 317,13 |
ret = radeon_get_atom_connector_info_from_object_table(dev); |
else |
ret = radeon_get_atom_connector_info_from_supported_devices_table(dev); |
} else { |
} else |
ret = radeon_get_legacy_connector_info_from_bios(dev); |
if (ret == false) |
ret = radeon_get_legacy_connector_info_from_table(dev); |
} |
} else { |
if (!ASIC_IS_AVIVO(rdev)) |
ret = radeon_get_legacy_connector_info_from_table(dev); |
} |
if (ret) { |
radeon_setup_encoder_clones(dev); |
radeon_print_display_setup(dev); |
list_for_each_entry(drm_connector, &dev->mode_config.connector_list, head) |
radeon_ddc_dump(drm_connector); |
363,19 → 336,12 |
{ |
int ret = 0; |
if ((radeon_connector->base.connector_type == DRM_MODE_CONNECTOR_DisplayPort) || |
(radeon_connector->base.connector_type == DRM_MODE_CONNECTOR_eDP)) { |
struct radeon_connector_atom_dig *dig = radeon_connector->con_priv; |
if ((dig->dp_sink_type == CONNECTOR_OBJECT_ID_DISPLAYPORT || |
dig->dp_sink_type == CONNECTOR_OBJECT_ID_eDP) && dig->dp_i2c_bus) |
radeon_connector->edid = drm_get_edid(&radeon_connector->base, &dig->dp_i2c_bus->adapter); |
} |
if (!radeon_connector->ddc_bus) |
return -1; |
if (!radeon_connector->edid) { |
radeon_i2c_do_lock(radeon_connector->ddc_bus, 1); |
radeon_i2c_do_lock(radeon_connector, 1); |
radeon_connector->edid = drm_get_edid(&radeon_connector->base, &radeon_connector->ddc_bus->adapter); |
radeon_i2c_do_lock(radeon_connector->ddc_bus, 0); |
radeon_i2c_do_lock(radeon_connector, 0); |
} |
if (radeon_connector->edid) { |
395,9 → 361,9 |
if (!radeon_connector->ddc_bus) |
return -1; |
radeon_i2c_do_lock(radeon_connector->ddc_bus, 1); |
radeon_i2c_do_lock(radeon_connector, 1); |
edid = drm_get_edid(connector, &radeon_connector->ddc_bus->adapter); |
radeon_i2c_do_lock(radeon_connector->ddc_bus, 0); |
radeon_i2c_do_lock(radeon_connector, 0); |
if (edid) { |
kfree(edid); |
} |
420,12 → 386,11 |
uint32_t *fb_div_p, |
uint32_t *frac_fb_div_p, |
uint32_t *ref_div_p, |
uint32_t *post_div_p) |
uint32_t *post_div_p, |
int flags) |
{ |
uint32_t min_ref_div = pll->min_ref_div; |
uint32_t max_ref_div = pll->max_ref_div; |
uint32_t min_post_div = pll->min_post_div; |
uint32_t max_post_div = pll->max_post_div; |
uint32_t min_fractional_feed_div = 0; |
uint32_t max_fractional_feed_div = 0; |
uint32_t best_vco = pll->best_vco; |
441,7 → 406,7 |
DRM_DEBUG("PLL freq %llu %u %u\n", freq, pll->min_ref_div, pll->max_ref_div); |
freq = freq * 1000; |
if (pll->flags & RADEON_PLL_USE_REF_DIV) |
if (flags & RADEON_PLL_USE_REF_DIV) |
min_ref_div = max_ref_div = pll->reference_div; |
else { |
while (min_ref_div < max_ref_div-1) { |
456,22 → 421,19 |
} |
} |
if (pll->flags & RADEON_PLL_USE_POST_DIV) |
min_post_div = max_post_div = pll->post_div; |
if (pll->flags & RADEON_PLL_USE_FRAC_FB_DIV) { |
if (flags & RADEON_PLL_USE_FRAC_FB_DIV) { |
min_fractional_feed_div = pll->min_frac_feedback_div; |
max_fractional_feed_div = pll->max_frac_feedback_div; |
} |
for (post_div = min_post_div; post_div <= max_post_div; ++post_div) { |
for (post_div = pll->min_post_div; post_div <= pll->max_post_div; ++post_div) { |
uint32_t ref_div; |
if ((pll->flags & RADEON_PLL_NO_ODD_POST_DIV) && (post_div & 1)) |
if ((flags & RADEON_PLL_NO_ODD_POST_DIV) && (post_div & 1)) |
continue; |
/* legacy radeons only have a few post_divs */ |
if (pll->flags & RADEON_PLL_LEGACY) { |
if (flags & RADEON_PLL_LEGACY) { |
if ((post_div == 5) || |
(post_div == 7) || |
(post_div == 9) || |
518,7 → 480,7 |
tmp += (uint64_t)pll->reference_freq * 1000 * frac_feedback_div; |
current_freq = radeon_div(tmp, ref_div * post_div); |
if (pll->flags & RADEON_PLL_PREFER_CLOSEST_LOWER) { |
if (flags & RADEON_PLL_PREFER_CLOSEST_LOWER) { |
error = freq - current_freq; |
error = error < 0 ? 0xffffffff : error; |
} else |
545,12 → 507,12 |
best_freq = current_freq; |
best_error = error; |
best_vco_diff = vco_diff; |
} else if (((pll->flags & RADEON_PLL_PREFER_LOW_REF_DIV) && (ref_div < best_ref_div)) || |
((pll->flags & RADEON_PLL_PREFER_HIGH_REF_DIV) && (ref_div > best_ref_div)) || |
((pll->flags & RADEON_PLL_PREFER_LOW_FB_DIV) && (feedback_div < best_feedback_div)) || |
((pll->flags & RADEON_PLL_PREFER_HIGH_FB_DIV) && (feedback_div > best_feedback_div)) || |
((pll->flags & RADEON_PLL_PREFER_LOW_POST_DIV) && (post_div < best_post_div)) || |
((pll->flags & RADEON_PLL_PREFER_HIGH_POST_DIV) && (post_div > best_post_div))) { |
} else if (((flags & RADEON_PLL_PREFER_LOW_REF_DIV) && (ref_div < best_ref_div)) || |
((flags & RADEON_PLL_PREFER_HIGH_REF_DIV) && (ref_div > best_ref_div)) || |
((flags & RADEON_PLL_PREFER_LOW_FB_DIV) && (feedback_div < best_feedback_div)) || |
((flags & RADEON_PLL_PREFER_HIGH_FB_DIV) && (feedback_div > best_feedback_div)) || |
((flags & RADEON_PLL_PREFER_LOW_POST_DIV) && (post_div < best_post_div)) || |
((flags & RADEON_PLL_PREFER_HIGH_POST_DIV) && (post_div > best_post_div))) { |
best_post_div = post_div; |
best_ref_div = ref_div; |
best_feedback_div = feedback_div; |
580,97 → 542,6 |
*post_div_p = best_post_div; |
} |
void radeon_compute_pll_avivo(struct radeon_pll *pll, |
uint64_t freq, |
uint32_t *dot_clock_p, |
uint32_t *fb_div_p, |
uint32_t *frac_fb_div_p, |
uint32_t *ref_div_p, |
uint32_t *post_div_p) |
{ |
fixed20_12 m, n, frac_n, p, f_vco, f_pclk, best_freq; |
fixed20_12 pll_out_max, pll_out_min; |
fixed20_12 pll_in_max, pll_in_min; |
fixed20_12 reference_freq; |
fixed20_12 error, ffreq, a, b; |
pll_out_max.full = rfixed_const(pll->pll_out_max); |
pll_out_min.full = rfixed_const(pll->pll_out_min); |
pll_in_max.full = rfixed_const(pll->pll_in_max); |
pll_in_min.full = rfixed_const(pll->pll_in_min); |
reference_freq.full = rfixed_const(pll->reference_freq); |
do_div(freq, 10); |
ffreq.full = rfixed_const(freq); |
error.full = rfixed_const(100 * 100); |
/* max p */ |
p.full = rfixed_div(pll_out_max, ffreq); |
p.full = rfixed_floor(p); |
/* min m */ |
m.full = rfixed_div(reference_freq, pll_in_max); |
m.full = rfixed_ceil(m); |
while (1) { |
n.full = rfixed_div(ffreq, reference_freq); |
n.full = rfixed_mul(n, m); |
n.full = rfixed_mul(n, p); |
f_vco.full = rfixed_div(n, m); |
f_vco.full = rfixed_mul(f_vco, reference_freq); |
f_pclk.full = rfixed_div(f_vco, p); |
if (f_pclk.full > ffreq.full) |
error.full = f_pclk.full - ffreq.full; |
else |
error.full = ffreq.full - f_pclk.full; |
error.full = rfixed_div(error, f_pclk); |
a.full = rfixed_const(100 * 100); |
error.full = rfixed_mul(error, a); |
a.full = rfixed_mul(m, p); |
a.full = rfixed_div(n, a); |
best_freq.full = rfixed_mul(reference_freq, a); |
if (rfixed_trunc(error) < 25) |
break; |
a.full = rfixed_const(1); |
m.full = m.full + a.full; |
a.full = rfixed_div(reference_freq, m); |
if (a.full >= pll_in_min.full) |
continue; |
m.full = rfixed_div(reference_freq, pll_in_max); |
m.full = rfixed_ceil(m); |
a.full= rfixed_const(1); |
p.full = p.full - a.full; |
a.full = rfixed_mul(p, ffreq); |
if (a.full >= pll_out_min.full) |
continue; |
else { |
DRM_ERROR("Unable to find pll dividers\n"); |
break; |
} |
} |
a.full = rfixed_const(10); |
b.full = rfixed_mul(n, a); |
frac_n.full = rfixed_floor(n); |
frac_n.full = rfixed_mul(frac_n, a); |
frac_n.full = b.full - frac_n.full; |
*dot_clock_p = rfixed_trunc(best_freq); |
*fb_div_p = rfixed_trunc(n); |
*frac_fb_div_p = rfixed_trunc(frac_n); |
*ref_div_p = rfixed_trunc(m); |
*post_div_p = rfixed_trunc(p); |
DRM_DEBUG("%u %d.%d, %d, %d\n", *dot_clock_p * 10, *fb_div_p, *frac_fb_div_p, *ref_div_p, *post_div_p); |
} |
static void radeon_user_framebuffer_destroy(struct drm_framebuffer *fb) |
{ |
struct radeon_framebuffer *radeon_fb = to_radeon_framebuffer(fb); |
761,7 → 632,7 |
{ TV_STD_SECAM, "secam" }, |
}; |
static int radeon_modeset_create_props(struct radeon_device *rdev) |
int radeon_modeset_create_props(struct radeon_device *rdev) |
{ |
int i, sz; |
774,7 → 645,7 |
return -ENOMEM; |
rdev->mode_info.coherent_mode_property->values[0] = 0; |
rdev->mode_info.coherent_mode_property->values[1] = 1; |
rdev->mode_info.coherent_mode_property->values[0] = 1; |
} |
if (!ASIC_IS_AVIVO(rdev)) { |
798,7 → 669,7 |
if (!rdev->mode_info.load_detect_property) |
return -ENOMEM; |
rdev->mode_info.load_detect_property->values[0] = 0; |
rdev->mode_info.load_detect_property->values[1] = 1; |
rdev->mode_info.load_detect_property->values[0] = 1; |
drm_mode_create_scaling_mode_property(rdev->ddev); |
855,8 → 726,6 |
if (!ret) { |
return ret; |
} |
/* initialize hpd */ |
radeon_hpd_init(rdev); |
drm_helper_initial_config(rdev->ddev); |
return 0; |
} |
864,7 → 733,6 |
void radeon_modeset_fini(struct radeon_device *rdev) |
{ |
if (rdev->mode_info.mode_config_initialized) { |
radeon_hpd_fini(rdev); |
drm_mode_config_cleanup(rdev->ddev); |
rdev->mode_info.mode_config_initialized = false; |
} |
885,15 → 753,7 |
if (encoder->crtc != crtc) |
continue; |
if (first) { |
/* set scaling */ |
if (radeon_encoder->rmx_type == RMX_OFF) |
radeon_crtc->rmx_type = RMX_OFF; |
else if (mode->hdisplay < radeon_encoder->native_mode.hdisplay || |
mode->vdisplay < radeon_encoder->native_mode.vdisplay) |
radeon_crtc->rmx_type = radeon_encoder->rmx_type; |
else |
radeon_crtc->rmx_type = RMX_OFF; |
/* copy native mode */ |
memcpy(&radeon_crtc->native_mode, |
&radeon_encoder->native_mode, |
sizeof(struct drm_display_mode)); |
/drivers/video/drm/radeon/cmdline.c |
---|
1,4 → 1,5 |
#include <stdint.h> |
#include <drm/drmP.h> |
#include <drm.h> |
#include <drm_mm.h> |
23,7 → 24,7 |
} |
} |
char* parse_mode(char *p, videomode_t *mode) |
char* parse_mode(char *p, mode_t *mode) |
{ |
char c; |
62,7 → 63,7 |
return p; |
}; |
void parse_cmdline(char *cmdline, videomode_t *mode, char *log, int *kms) |
void parse_cmdline(char *cmdline, mode_t *mode, char *log, int *kms) |
{ |
char *p = cmdline; |
/drivers/video/drm/radeon/radeon_cursor.c |
---|
0,0 → 1,260 |
/* |
* Copyright 2007-8 Advanced Micro Devices, Inc. |
* Copyright 2008 Red Hat Inc. |
* |
* Permission is hereby granted, free of charge, to any person obtaining a |
* copy of this software and associated documentation files (the "Software"), |
* to deal in the Software without restriction, including without limitation |
* the rights to use, copy, modify, merge, publish, distribute, sublicense, |
* and/or sell copies of the Software, and to permit persons to whom the |
* Software is furnished to do so, subject to the following conditions: |
* |
* The above copyright notice and this permission notice shall be included in |
* all copies or substantial portions of the Software. |
* |
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR |
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, |
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR |
* OTHER DEALINGS IN THE SOFTWARE. |
* |
* Authors: Dave Airlie |
* Alex Deucher |
*/ |
#include "drmP.h" |
#include "radeon_drm.h" |
#include "radeon.h" |
#define CURSOR_WIDTH 64 |
#define CURSOR_HEIGHT 64 |
static void radeon_lock_cursor(struct drm_crtc *crtc, bool lock) |
{ |
struct radeon_device *rdev = crtc->dev->dev_private; |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
uint32_t cur_lock; |
if (ASIC_IS_AVIVO(rdev)) { |
cur_lock = RREG32(AVIVO_D1CUR_UPDATE + radeon_crtc->crtc_offset); |
if (lock) |
cur_lock |= AVIVO_D1CURSOR_UPDATE_LOCK; |
else |
cur_lock &= ~AVIVO_D1CURSOR_UPDATE_LOCK; |
WREG32(AVIVO_D1CUR_UPDATE + radeon_crtc->crtc_offset, cur_lock); |
} else { |
cur_lock = RREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset); |
if (lock) |
cur_lock |= RADEON_CUR_LOCK; |
else |
cur_lock &= ~RADEON_CUR_LOCK; |
WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, cur_lock); |
} |
} |
static void radeon_hide_cursor(struct drm_crtc *crtc) |
{ |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
struct radeon_device *rdev = crtc->dev->dev_private; |
if (ASIC_IS_AVIVO(rdev)) { |
WREG32(RADEON_MM_INDEX, AVIVO_D1CUR_CONTROL + radeon_crtc->crtc_offset); |
WREG32(RADEON_MM_DATA, (AVIVO_D1CURSOR_MODE_24BPP << AVIVO_D1CURSOR_MODE_SHIFT)); |
} else { |
switch (radeon_crtc->crtc_id) { |
case 0: |
WREG32(RADEON_MM_INDEX, RADEON_CRTC_GEN_CNTL); |
break; |
case 1: |
WREG32(RADEON_MM_INDEX, RADEON_CRTC2_GEN_CNTL); |
break; |
default: |
return; |
} |
WREG32_P(RADEON_MM_DATA, 0, ~RADEON_CRTC_CUR_EN); |
} |
} |
static void radeon_show_cursor(struct drm_crtc *crtc) |
{ |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
struct radeon_device *rdev = crtc->dev->dev_private; |
if (ASIC_IS_AVIVO(rdev)) { |
WREG32(RADEON_MM_INDEX, AVIVO_D1CUR_CONTROL + radeon_crtc->crtc_offset); |
WREG32(RADEON_MM_DATA, AVIVO_D1CURSOR_EN | |
(AVIVO_D1CURSOR_MODE_24BPP << AVIVO_D1CURSOR_MODE_SHIFT)); |
} else { |
switch (radeon_crtc->crtc_id) { |
case 0: |
WREG32(RADEON_MM_INDEX, RADEON_CRTC_GEN_CNTL); |
break; |
case 1: |
WREG32(RADEON_MM_INDEX, RADEON_CRTC2_GEN_CNTL); |
break; |
default: |
return; |
} |
WREG32_P(RADEON_MM_DATA, (RADEON_CRTC_CUR_EN | |
(RADEON_CRTC_CUR_MODE_24BPP << RADEON_CRTC_CUR_MODE_SHIFT)), |
~(RADEON_CRTC_CUR_EN | RADEON_CRTC_CUR_MODE_MASK)); |
} |
} |
static void radeon_set_cursor(struct drm_crtc *crtc, struct drm_gem_object *obj, |
uint32_t gpu_addr) |
{ |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
struct radeon_device *rdev = crtc->dev->dev_private; |
if (ASIC_IS_AVIVO(rdev)) |
WREG32(AVIVO_D1CUR_SURFACE_ADDRESS + radeon_crtc->crtc_offset, gpu_addr); |
else { |
radeon_crtc->legacy_cursor_offset = gpu_addr - radeon_crtc->legacy_display_base_addr; |
/* offset is from DISP(2)_BASE_ADDRESS */ |
WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, radeon_crtc->legacy_cursor_offset); |
} |
} |
#if 0 |
int radeon_crtc_cursor_set(struct drm_crtc *crtc, |
struct drm_file *file_priv, |
uint32_t handle, |
uint32_t width, |
uint32_t height) |
{ |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
struct drm_gem_object *obj; |
uint64_t gpu_addr; |
int ret; |
if (!handle) { |
/* turn off cursor */ |
radeon_hide_cursor(crtc); |
obj = NULL; |
goto unpin; |
} |
if ((width > CURSOR_WIDTH) || (height > CURSOR_HEIGHT)) { |
DRM_ERROR("bad cursor width or height %d x %d\n", width, height); |
return -EINVAL; |
} |
radeon_crtc->cursor_width = width; |
radeon_crtc->cursor_height = height; |
obj = drm_gem_object_lookup(crtc->dev, file_priv, handle); |
if (!obj) { |
DRM_ERROR("Cannot find cursor object %x for crtc %d\n", handle, radeon_crtc->crtc_id); |
return -EINVAL; |
} |
ret = radeon_gem_object_pin(obj, RADEON_GEM_DOMAIN_VRAM, &gpu_addr); |
if (ret) |
goto fail; |
radeon_lock_cursor(crtc, true); |
/* XXX only 27 bit offset for legacy cursor */ |
radeon_set_cursor(crtc, obj, gpu_addr); |
radeon_show_cursor(crtc); |
radeon_lock_cursor(crtc, false); |
unpin: |
if (radeon_crtc->cursor_bo) { |
radeon_gem_object_unpin(radeon_crtc->cursor_bo); |
mutex_lock(&crtc->dev->struct_mutex); |
drm_gem_object_unreference(radeon_crtc->cursor_bo); |
mutex_unlock(&crtc->dev->struct_mutex); |
} |
radeon_crtc->cursor_bo = obj; |
return 0; |
fail: |
mutex_lock(&crtc->dev->struct_mutex); |
drm_gem_object_unreference(obj); |
mutex_unlock(&crtc->dev->struct_mutex); |
return 0; |
} |
#endif |
int radeon_crtc_cursor_move(struct drm_crtc *crtc, |
int x, int y) |
{ |
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
struct radeon_device *rdev = crtc->dev->dev_private; |
int xorigin = 0, yorigin = 0; |
if (x < 0) |
xorigin = -x + 1; |
if (y < 0) |
yorigin = -y + 1; |
if (xorigin >= CURSOR_WIDTH) |
xorigin = CURSOR_WIDTH - 1; |
if (yorigin >= CURSOR_HEIGHT) |
yorigin = CURSOR_HEIGHT - 1; |
radeon_lock_cursor(crtc, true); |
if (ASIC_IS_AVIVO(rdev)) { |
int w = radeon_crtc->cursor_width; |
int i = 0; |
struct drm_crtc *crtc_p; |
/* avivo cursor are offset into the total surface */ |
x += crtc->x; |
y += crtc->y; |
DRM_DEBUG("x %d y %d c->x %d c->y %d\n", x, y, crtc->x, crtc->y); |
/* avivo cursor image can't end on 128 pixel boundry or |
* go past the end of the frame if both crtcs are enabled |
*/ |
list_for_each_entry(crtc_p, &crtc->dev->mode_config.crtc_list, head) { |
if (crtc_p->enabled) |
i++; |
} |
if (i > 1) { |
int cursor_end, frame_end; |
cursor_end = x - xorigin + w; |
frame_end = crtc->x + crtc->mode.crtc_hdisplay; |
if (cursor_end >= frame_end) { |
w = w - (cursor_end - frame_end); |
if (!(frame_end & 0x7f)) |
w--; |
} else { |
if (!(cursor_end & 0x7f)) |
w--; |
} |
if (w <= 0) |
w = 1; |
} |
WREG32(AVIVO_D1CUR_POSITION + radeon_crtc->crtc_offset, |
((xorigin ? 0 : x) << 16) | |
(yorigin ? 0 : y)); |
WREG32(AVIVO_D1CUR_HOT_SPOT + radeon_crtc->crtc_offset, (xorigin << 16) | yorigin); |
WREG32(AVIVO_D1CUR_SIZE + radeon_crtc->crtc_offset, |
((w - 1) << 16) | (radeon_crtc->cursor_height - 1)); |
} else { |
if (crtc->mode.flags & DRM_MODE_FLAG_DBLSCAN) |
y *= 2; |
WREG32(RADEON_CUR_HORZ_VERT_OFF + radeon_crtc->crtc_offset, |
(RADEON_CUR_LOCK |
| (xorigin << 16) |
| yorigin)); |
WREG32(RADEON_CUR_HORZ_VERT_POSN + radeon_crtc->crtc_offset, |
(RADEON_CUR_LOCK |
| ((xorigin ? 0 : x) << 16) |
| (yorigin ? 0 : y))); |
/* offset is from DISP(2)_BASE_ADDRESS */ |
WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, (radeon_crtc->legacy_cursor_offset + |
(yorigin * 256))); |
} |
radeon_lock_cursor(crtc, false); |
return 0; |
} |
/drivers/video/drm/radeon/radeon_gem.c |
---|
30,6 → 30,31 |
#include "radeon_drm.h" |
#include "radeon.h" |
#define TTM_PL_SYSTEM 0 |
#define TTM_PL_TT 1 |
#define TTM_PL_VRAM 2 |
#define TTM_PL_PRIV0 3 |
#define TTM_PL_PRIV1 4 |
#define TTM_PL_PRIV2 5 |
#define TTM_PL_PRIV3 6 |
#define TTM_PL_PRIV4 7 |
#define TTM_PL_PRIV5 8 |
#define TTM_PL_SWAPPED 15 |
#define TTM_PL_FLAG_SYSTEM (1 << TTM_PL_SYSTEM) |
#define TTM_PL_FLAG_TT (1 << TTM_PL_TT) |
#define TTM_PL_FLAG_VRAM (1 << TTM_PL_VRAM) |
#define TTM_PL_FLAG_PRIV0 (1 << TTM_PL_PRIV0) |
#define TTM_PL_FLAG_PRIV1 (1 << TTM_PL_PRIV1) |
#define TTM_PL_FLAG_PRIV2 (1 << TTM_PL_PRIV2) |
#define TTM_PL_FLAG_PRIV3 (1 << TTM_PL_PRIV3) |
#define TTM_PL_FLAG_PRIV4 (1 << TTM_PL_PRIV4) |
#define TTM_PL_FLAG_PRIV5 (1 << TTM_PL_PRIV5) |
#define TTM_PL_FLAG_SWAPPED (1 << TTM_PL_SWAPPED) |
#define TTM_PL_MASK_MEM 0x0000FFFF |
int radeon_gem_object_init(struct drm_gem_object *obj) |
{ |
/* we do nothings here */ |
38,11 → 63,11 |
void radeon_gem_object_free(struct drm_gem_object *gobj) |
{ |
struct radeon_bo *robj = gobj->driver_private; |
struct radeon_object *robj = gobj->driver_private; |
gobj->driver_private = NULL; |
if (robj) { |
radeon_bo_unref(&robj); |
// radeon_object_unref(&robj); |
} |
} |
49,10 → 74,11 |
int radeon_gem_object_create(struct radeon_device *rdev, int size, |
int alignment, int initial_domain, |
bool discardable, bool kernel, |
bool interruptible, |
struct drm_gem_object **obj) |
{ |
struct drm_gem_object *gobj; |
struct radeon_bo *robj; |
struct radeon_object *robj; |
int r; |
*obj = NULL; |
64,10 → 90,14 |
if (alignment < PAGE_SIZE) { |
alignment = PAGE_SIZE; |
} |
r = radeon_fb_bo_create(rdev, gobj, size, kernel, initial_domain, &robj); |
r = radeon_object_create(rdev, gobj, size, kernel, initial_domain, |
interruptible, &robj); |
if (r) { |
DRM_ERROR("Failed to allocate GEM object (%d, %d, %u)\n", |
size, initial_domain, alignment); |
// mutex_lock(&rdev->ddev->struct_mutex); |
// drm_gem_object_unreference(gobj); |
// mutex_unlock(&rdev->ddev->struct_mutex); |
return r; |
} |
gobj->driver_private = robj; |
78,33 → 108,33 |
int radeon_gem_object_pin(struct drm_gem_object *obj, uint32_t pin_domain, |
uint64_t *gpu_addr) |
{ |
struct radeon_bo *robj = obj->driver_private; |
int r; |
struct radeon_object *robj = obj->driver_private; |
uint32_t flags; |
r = radeon_bo_reserve(robj, false); |
if (unlikely(r != 0)) |
return r; |
r = radeon_bo_pin(robj, pin_domain, gpu_addr); |
radeon_bo_unreserve(robj); |
return r; |
switch (pin_domain) { |
case RADEON_GEM_DOMAIN_VRAM: |
flags = TTM_PL_FLAG_VRAM; |
break; |
case RADEON_GEM_DOMAIN_GTT: |
flags = TTM_PL_FLAG_TT; |
break; |
default: |
flags = TTM_PL_FLAG_SYSTEM; |
break; |
} |
return radeon_object_pin(robj, flags, gpu_addr); |
} |
void radeon_gem_object_unpin(struct drm_gem_object *obj) |
{ |
struct radeon_bo *robj = obj->driver_private; |
int r; |
r = radeon_bo_reserve(robj, false); |
if (likely(r == 0)) { |
radeon_bo_unpin(robj); |
radeon_bo_unreserve(robj); |
struct radeon_object *robj = obj->driver_private; |
// radeon_object_unpin(robj); |
} |
} |
int radeon_gem_set_domain(struct drm_gem_object *gobj, |
uint32_t rdomain, uint32_t wdomain) |
{ |
struct radeon_bo *robj; |
struct radeon_object *robj; |
uint32_t domain; |
int r; |
122,12 → 152,12 |
} |
if (domain == RADEON_GEM_DOMAIN_CPU) { |
/* Asking for cpu access wait for object idle */ |
// r = radeon_bo_wait(robj, NULL, false); |
// if (r) { |
// printk(KERN_ERR "Failed to wait for object !\n"); |
// return r; |
// } |
// r = radeon_object_wait(robj); |
if (r) { |
printk(KERN_ERR "Failed to wait for object !\n"); |
return r; |
} |
} |
return 0; |
} |
188,7 → 218,7 |
args->size = roundup(args->size, PAGE_SIZE); |
r = radeon_gem_object_create(rdev, args->size, args->alignment, |
args->initial_domain, false, |
false, &gobj); |
false, true, &gobj); |
if (r) { |
return r; |
} |
213,7 → 243,7 |
* just validate the BO into a certain domain */ |
struct drm_radeon_gem_set_domain *args = data; |
struct drm_gem_object *gobj; |
struct radeon_bo *robj; |
struct radeon_object *robj; |
int r; |
/* for now if someone requests domain CPU - |
239,7 → 269,8 |
{ |
struct drm_radeon_gem_mmap *args = data; |
struct drm_gem_object *gobj; |
struct radeon_bo *robj; |
struct radeon_object *robj; |
int r; |
gobj = drm_gem_object_lookup(dev, filp, args->handle); |
if (gobj == NULL) { |
246,45 → 277,19 |
return -EINVAL; |
} |
robj = gobj->driver_private; |
args->addr_ptr = radeon_bo_mmap_offset(robj); |
r = radeon_object_mmap(robj, &args->addr_ptr); |
mutex_lock(&dev->struct_mutex); |
drm_gem_object_unreference(gobj); |
mutex_unlock(&dev->struct_mutex); |
return 0; |
return r; |
} |
int radeon_gem_busy_ioctl(struct drm_device *dev, void *data, |
struct drm_file *filp) |
{ |
struct drm_radeon_gem_busy *args = data; |
struct drm_gem_object *gobj; |
struct radeon_bo *robj; |
int r; |
uint32_t cur_placement = 0; |
gobj = drm_gem_object_lookup(dev, filp, args->handle); |
if (gobj == NULL) { |
return -EINVAL; |
/* FIXME: implement */ |
return 0; |
} |
robj = gobj->driver_private; |
r = radeon_bo_wait(robj, &cur_placement, true); |
switch (cur_placement) { |
case TTM_PL_VRAM: |
args->domain = RADEON_GEM_DOMAIN_VRAM; |
break; |
case TTM_PL_TT: |
args->domain = RADEON_GEM_DOMAIN_GTT; |
break; |
case TTM_PL_SYSTEM: |
args->domain = RADEON_GEM_DOMAIN_CPU; |
default: |
break; |
} |
mutex_lock(&dev->struct_mutex); |
drm_gem_object_unreference(gobj); |
mutex_unlock(&dev->struct_mutex); |
return r; |
} |
int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data, |
struct drm_file *filp) |
291,7 → 296,7 |
{ |
struct drm_radeon_gem_wait_idle *args = data; |
struct drm_gem_object *gobj; |
struct radeon_bo *robj; |
struct radeon_object *robj; |
int r; |
gobj = drm_gem_object_lookup(dev, filp, args->handle); |
299,10 → 304,7 |
return -EINVAL; |
} |
robj = gobj->driver_private; |
r = radeon_bo_wait(robj, NULL, false); |
/* callback hw specific functions if any */ |
if (robj->rdev->asic->ioctl_wait_idle) |
robj->rdev->asic->ioctl_wait_idle(robj->rdev, robj); |
r = radeon_object_wait(robj); |
mutex_lock(&dev->struct_mutex); |
drm_gem_object_unreference(gobj); |
mutex_unlock(&dev->struct_mutex); |
309,24 → 311,4 |
return r; |
} |
int radeon_gem_set_tiling_ioctl(struct drm_device *dev, void *data, |
struct drm_file *filp) |
{ |
struct drm_radeon_gem_set_tiling *args = data; |
struct drm_gem_object *gobj; |
struct radeon_bo *robj; |
int r = 0; |
DRM_DEBUG("%d \n", args->handle); |
gobj = drm_gem_object_lookup(dev, filp, args->handle); |
if (gobj == NULL) |
return -EINVAL; |
robj = gobj->driver_private; |
r = radeon_bo_set_tiling_flags(robj, args->tiling_flags, args->pitch); |
mutex_lock(&dev->struct_mutex); |
drm_gem_object_unreference(gobj); |
mutex_unlock(&dev->struct_mutex); |
return r; |
} |
#endif |
/drivers/video/drm/radeon/radeon_legacy_tv.c |
---|
77,7 → 77,7 |
unsigned pix_to_tv; |
}; |
static const uint16_t hor_timing_NTSC[MAX_H_CODE_TIMING_LEN] = { |
static const uint16_t hor_timing_NTSC[] = { |
0x0007, |
0x003f, |
0x0263, |
98,7 → 98,7 |
0 |
}; |
static const uint16_t vert_timing_NTSC[MAX_V_CODE_TIMING_LEN] = { |
static const uint16_t vert_timing_NTSC[] = { |
0x2001, |
0x200d, |
0x1006, |
115,7 → 115,7 |
0 |
}; |
static const uint16_t hor_timing_PAL[MAX_H_CODE_TIMING_LEN] = { |
static const uint16_t hor_timing_PAL[] = { |
0x0007, |
0x0058, |
0x027c, |
136,7 → 136,7 |
0 |
}; |
static const uint16_t vert_timing_PAL[MAX_V_CODE_TIMING_LEN] = { |
static const uint16_t vert_timing_PAL[] = { |
0x2001, |
0x200c, |
0x1005, |
623,9 → 623,9 |
} |
flicker_removal = (tmp + 500) / 1000; |
if (flicker_removal < 2) |
flicker_removal = 2; |
for (i = 0; i < ARRAY_SIZE(SLOPE_limit); ++i) { |
if (flicker_removal < 3) |
flicker_removal = 3; |
for (i = 0; i < 6; ++i) { |
if (flicker_removal == SLOPE_limit[i]) |
break; |
} |
/drivers/video/drm/radeon/radeon_ring.c |
---|
169,24 → 169,19 |
return 0; |
/* Allocate 1M object buffer */ |
INIT_LIST_HEAD(&rdev->ib_pool.scheduled_ibs); |
r = radeon_bo_create(rdev, NULL, RADEON_IB_POOL_SIZE*64*1024, |
r = radeon_object_create(rdev, NULL, RADEON_IB_POOL_SIZE*64*1024, |
true, RADEON_GEM_DOMAIN_GTT, |
&rdev->ib_pool.robj); |
false, &rdev->ib_pool.robj); |
if (r) { |
DRM_ERROR("radeon: failed to ib pool (%d).\n", r); |
return r; |
} |
r = radeon_bo_reserve(rdev->ib_pool.robj, false); |
if (unlikely(r != 0)) |
return r; |
r = radeon_bo_pin(rdev->ib_pool.robj, RADEON_GEM_DOMAIN_GTT, &gpu_addr); |
r = radeon_object_pin(rdev->ib_pool.robj, RADEON_GEM_DOMAIN_GTT, &gpu_addr); |
if (r) { |
radeon_bo_unreserve(rdev->ib_pool.robj); |
DRM_ERROR("radeon: failed to pin ib pool (%d).\n", r); |
return r; |
} |
r = radeon_bo_kmap(rdev->ib_pool.robj, &ptr); |
radeon_bo_unreserve(rdev->ib_pool.robj); |
r = radeon_object_kmap(rdev->ib_pool.robj, &ptr); |
if (r) { |
DRM_ERROR("radeon: failed to map ib poll (%d).\n", r); |
return r; |
212,8 → 207,6 |
void radeon_ib_pool_fini(struct radeon_device *rdev) |
{ |
int r; |
if (!rdev->ib_pool.ready) { |
return; |
} |
220,13 → 213,8 |
mutex_lock(&rdev->ib_pool.mutex); |
bitmap_zero(rdev->ib_pool.alloc_bm, RADEON_IB_POOL_SIZE); |
if (rdev->ib_pool.robj) { |
r = radeon_bo_reserve(rdev->ib_pool.robj, false); |
if (likely(r == 0)) { |
radeon_bo_kunmap(rdev->ib_pool.robj); |
radeon_bo_unpin(rdev->ib_pool.robj); |
radeon_bo_unreserve(rdev->ib_pool.robj); |
} |
radeon_bo_unref(&rdev->ib_pool.robj); |
// radeon_object_kunmap(rdev->ib_pool.robj); |
// radeon_object_unref(&rdev->ib_pool.robj); |
rdev->ib_pool.robj = NULL; |
} |
mutex_unlock(&rdev->ib_pool.mutex); |
306,31 → 294,46 |
rdev->cp.ring_size = ring_size; |
/* Allocate ring buffer */ |
if (rdev->cp.ring_obj == NULL) { |
r = radeon_bo_create(rdev, NULL, rdev->cp.ring_size, true, |
r = radeon_object_create(rdev, NULL, rdev->cp.ring_size, |
true, |
RADEON_GEM_DOMAIN_GTT, |
false, |
&rdev->cp.ring_obj); |
if (r) { |
dev_err(rdev->dev, "(%d) ring create failed\n", r); |
DRM_ERROR("radeon: failed to create ring buffer (%d).\n", r); |
mutex_unlock(&rdev->cp.mutex); |
return r; |
} |
r = radeon_bo_reserve(rdev->cp.ring_obj, false); |
if (unlikely(r != 0)) |
return r; |
r = radeon_bo_pin(rdev->cp.ring_obj, RADEON_GEM_DOMAIN_GTT, |
r = radeon_object_pin(rdev->cp.ring_obj, |
RADEON_GEM_DOMAIN_GTT, |
&rdev->cp.gpu_addr); |
if (r) { |
radeon_bo_unreserve(rdev->cp.ring_obj); |
dev_err(rdev->dev, "(%d) ring pin failed\n", r); |
DRM_ERROR("radeon: failed to pin ring buffer (%d).\n", r); |
mutex_unlock(&rdev->cp.mutex); |
return r; |
} |
r = radeon_bo_kmap(rdev->cp.ring_obj, |
r = radeon_object_kmap(rdev->cp.ring_obj, |
(void **)&rdev->cp.ring); |
radeon_bo_unreserve(rdev->cp.ring_obj); |
if (r) { |
dev_err(rdev->dev, "(%d) ring map failed\n", r); |
DRM_ERROR("radeon: failed to map ring buffer (%d).\n", r); |
mutex_unlock(&rdev->cp.mutex); |
return r; |
} |
} |
// rdev->cp.ring = CreateRingBuffer( ring_size, PG_SW ); |
dbgprintf("ring buffer %x\n", rdev->cp.ring ); |
// rdev->cp.gpu_addr = rdev->mc.gtt_location; |
// u32_t *pagelist = &((u32_t*)page_tabs)[(u32_t)rdev->cp.ring >> 12]; |
// dbgprintf("pagelist %x\n", pagelist); |
// radeon_gart_bind(rdev, 0, ring_size / 4096, pagelist); |
rdev->cp.ptr_mask = (rdev->cp.ring_size / 4) - 1; |
rdev->cp.ring_free_dw = rdev->cp.ring_size / 4; |
341,17 → 344,11 |
void radeon_ring_fini(struct radeon_device *rdev) |
{ |
int r; |
mutex_lock(&rdev->cp.mutex); |
if (rdev->cp.ring_obj) { |
r = radeon_bo_reserve(rdev->cp.ring_obj, false); |
if (likely(r == 0)) { |
radeon_bo_kunmap(rdev->cp.ring_obj); |
radeon_bo_unpin(rdev->cp.ring_obj); |
radeon_bo_unreserve(rdev->cp.ring_obj); |
} |
radeon_bo_unref(&rdev->cp.ring_obj); |
// radeon_object_kunmap(rdev->cp.ring_obj); |
// radeon_object_unpin(rdev->cp.ring_obj); |
// radeon_object_unref(&rdev->cp.ring_obj); |
rdev->cp.ring = NULL; |
rdev->cp.ring_obj = NULL; |
} |
/drivers/video/drm/drm_crtc.c |
---|
158,7 → 158,6 |
{ DRM_MODE_CONNECTOR_HDMIA, "HDMI Type A", 0 }, |
{ DRM_MODE_CONNECTOR_HDMIB, "HDMI Type B", 0 }, |
{ DRM_MODE_CONNECTOR_TV, "TV", 0 }, |
{ DRM_MODE_CONNECTOR_eDP, "Embedded DisplayPort", 0 }, |
}; |
static struct drm_prop_enum_list drm_encoder_enum_list[] = |
/drivers/video/drm/drm_crtc_helper.c |
---|
216,7 → 216,7 |
EXPORT_SYMBOL(drm_helper_crtc_in_use); |
/** |
* drm_helper_disable_unused_functions - disable unused objects |
* drm_disable_unused_functions - disable unused objects |
* @dev: DRM device |
* |
* LOCKING: |
572,7 → 572,7 |
struct drm_crtc *tmp; |
int crtc_mask = 1; |
WARN(!crtc, "checking null crtc?"); |
// WARN(!crtc, "checking null crtc?"); |
dev = crtc->dev; |
702,7 → 702,7 |
if (encoder->crtc != crtc) |
continue; |
DRM_DEBUG("%s: set mode %s %x\n", drm_get_encoder_name(encoder), |
DRM_INFO("%s: set mode %s %x\n", drm_get_encoder_name(encoder), |
mode->name, mode->base.id); |
encoder_funcs = encoder->helper_private; |
encoder_funcs->mode_set(encoder, mode, adjusted_mode); |
1021,9 → 1021,9 |
int count = 0; |
/* disable all the possible outputs/crtcs before entering KMS mode */ |
// drm_helper_disable_unused_functions(dev); |
drm_helper_disable_unused_functions(dev); |
// drm_fb_helper_parse_command_line(dev); |
drm_fb_helper_parse_command_line(dev); |
count = drm_helper_probe_connector_modes(dev, |
dev->mode_config.max_width, |
1032,8 → 1032,7 |
/* |
* we shouldn't end up with no modes here. |
*/ |
if (count == 0) |
printk(KERN_INFO "No connectors reported connected with modes\n"); |
// WARN(!count, "Connected connector with 0 modes\n"); |
drm_setup_crtcs(dev); |
1163,9 → 1162,6 |
int drm_helper_resume_force_mode(struct drm_device *dev) |
{ |
struct drm_crtc *crtc; |
struct drm_encoder *encoder; |
struct drm_encoder_helper_funcs *encoder_funcs; |
struct drm_crtc_helper_funcs *crtc_funcs; |
int ret; |
list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) { |
1178,26 → 1174,7 |
if (ret == false) |
DRM_ERROR("failed to set mode on crtc %p\n", crtc); |
/* Turn off outputs that were already powered off */ |
if (drm_helper_choose_crtc_dpms(crtc)) { |
list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) { |
if(encoder->crtc != crtc) |
continue; |
encoder_funcs = encoder->helper_private; |
if (encoder_funcs->dpms) |
(*encoder_funcs->dpms) (encoder, |
drm_helper_choose_encoder_dpms(encoder)); |
crtc_funcs = crtc->helper_private; |
if (crtc_funcs->dpms) |
(*crtc_funcs->dpms) (crtc, |
drm_helper_choose_crtc_dpms(crtc)); |
} |
} |
} |
/* disable the unused connectors while restoring the modesetting */ |
drm_helper_disable_unused_functions(dev); |
return 0; |
/drivers/video/drm/drm_edid.c |
---|
633,7 → 633,8 |
return NULL; |
} |
if (!(pt->misc & DRM_EDID_PT_SEPARATE_SYNC)) { |
printk(KERN_WARNING "composite sync not supported\n"); |
printk(KERN_WARNING "integrated sync not supported\n"); |
return NULL; |
} |
/* it is incorrect if hsync/vsync width is zero */ |
910,27 → 911,23 |
struct drm_device *dev = connector->dev; |
struct cvt_timing *cvt; |
const int rates[] = { 60, 85, 75, 60, 50 }; |
const u8 empty[3] = { 0, 0, 0 }; |
for (i = 0; i < 4; i++) { |
int uninitialized_var(width), height; |
int width, height; |
cvt = &(timing->data.other_data.data.cvt[i]); |
if (!memcmp(cvt->code, empty, 3)) |
continue; |
height = (cvt->code[0] + ((cvt->code[1] & 0xf0) << 4) + 1) * 2; |
switch (cvt->code[1] & 0x0c) { |
height = (cvt->code[0] + ((cvt->code[1] & 0xf0) << 8) + 1) * 2; |
switch (cvt->code[1] & 0xc0) { |
case 0x00: |
width = height * 4 / 3; |
break; |
case 0x04: |
case 0x40: |
width = height * 16 / 9; |
break; |
case 0x08: |
case 0x80: |
width = height * 16 / 10; |
break; |
case 0x0c: |
case 0xc0: |
width = height * 15 / 9; |
break; |
} |
/drivers/video/drm/drm_fb_helper.c |
---|
175,7 → 175,7 |
break; |
/* Display: Off; HSync: On, VSync: On */ |
case FB_BLANK_NORMAL: |
drm_fb_helper_off(info, DRM_MODE_DPMS_STANDBY); |
drm_fb_helper_off(info, DRM_MODE_DPMS_ON); |
break; |
/* Display: Off; HSync: Off, VSync: On */ |
case FB_BLANK_HSYNC_SUSPEND: |
392,10 → 392,11 |
return -EINVAL; |
/* Need to resize the fb object !!! */ |
if (var->bits_per_pixel > fb->bits_per_pixel || var->xres > fb->width || var->yres > fb->height) { |
DRM_DEBUG("fb userspace requested width/height/bpp is greater than current fb " |
"object %dx%d-%d > %dx%d-%d\n", var->xres, var->yres, var->bits_per_pixel, |
fb->width, fb->height, fb->bits_per_pixel); |
if (var->xres > fb->width || var->yres > fb->height) { |
DRM_ERROR("Requested width/height is greater than current fb " |
"object %dx%d > %dx%d\n", var->xres, var->yres, |
fb->width, fb->height); |
DRM_ERROR("Need resizing code.\n"); |
return -EINVAL; |
} |
/drivers/video/drm/drm_mm.c |
---|
355,7 → 355,7 |
if (entry->size >= size + wasted) { |
if (!best_match) |
return entry; |
if (entry->size < best_size) { |
if (size < best_size) { |
best = entry; |
best_size = entry->size; |
} |
405,7 → 405,7 |
if (entry->size >= size + wasted) { |
if (!best_match) |
return entry; |
if (entry->size < best_size) { |
if (size < best_size) { |
best = entry; |
best_size = entry->size; |
} |
/drivers/video/drm/drm_modes.c |
---|
1,4 → 1,9 |
/* |
* The list_sort function is (presumably) licensed under the GPL (see the |
* top level "COPYING" file for details). |
* |
* The remainder of this file is: |
* |
* Copyright © 1997-2003 by The XFree86 Project, Inc. |
* Copyright © 2007 Dave Airlie |
* Copyright © 2007-2008 Intel Corporation |
31,7 → 36,6 |
*/ |
#include <linux/list.h> |
#include <linux/list_sort.h> |
#include "drmP.h" |
#include "drm.h" |
#include "drm_crtc.h" |
851,7 → 855,6 |
/** |
* drm_mode_compare - compare modes for favorability |
* @priv: unused |
* @lh_a: list_head for first mode |
* @lh_b: list_head for second mode |
* |
865,7 → 868,7 |
* Negative if @lh_a is better than @lh_b, zero if they're equivalent, or |
* positive if @lh_b is better than @lh_a. |
*/ |
static int drm_mode_compare(void *priv, struct list_head *lh_a, struct list_head *lh_b) |
static int drm_mode_compare(struct list_head *lh_a, struct list_head *lh_b) |
{ |
struct drm_display_mode *a = list_entry(lh_a, struct drm_display_mode, head); |
struct drm_display_mode *b = list_entry(lh_b, struct drm_display_mode, head); |
882,6 → 885,85 |
return diff; |
} |
/* FIXME: what we don't have a list sort function? */ |
/* list sort from Mark J Roberts (mjr@znex.org) */ |
void list_sort(struct list_head *head, |
int (*cmp)(struct list_head *a, struct list_head *b)) |
{ |
struct list_head *p, *q, *e, *list, *tail, *oldhead; |
int insize, nmerges, psize, qsize, i; |
list = head->next; |
list_del(head); |
insize = 1; |
for (;;) { |
p = oldhead = list; |
list = tail = NULL; |
nmerges = 0; |
while (p) { |
nmerges++; |
q = p; |
psize = 0; |
for (i = 0; i < insize; i++) { |
psize++; |
q = q->next == oldhead ? NULL : q->next; |
if (!q) |
break; |
} |
qsize = insize; |
while (psize > 0 || (qsize > 0 && q)) { |
if (!psize) { |
e = q; |
q = q->next; |
qsize--; |
if (q == oldhead) |
q = NULL; |
} else if (!qsize || !q) { |
e = p; |
p = p->next; |
psize--; |
if (p == oldhead) |
p = NULL; |
} else if (cmp(p, q) <= 0) { |
e = p; |
p = p->next; |
psize--; |
if (p == oldhead) |
p = NULL; |
} else { |
e = q; |
q = q->next; |
qsize--; |
if (q == oldhead) |
q = NULL; |
} |
if (tail) |
tail->next = e; |
else |
list = e; |
e->prev = tail; |
tail = e; |
} |
p = q; |
} |
tail->next = list; |
list->prev = tail; |
if (nmerges <= 1) |
break; |
insize *= 2; |
} |
head->next = list; |
head->prev = list->prev; |
list->prev->next = head; |
list->prev = head; |
} |
/** |
* drm_mode_sort - sort mode list |
* @mode_list: list to sort |
893,7 → 975,7 |
*/ |
void drm_mode_sort(struct list_head *mode_list) |
{ |
list_sort(NULL, mode_list, drm_mode_compare); |
list_sort(mode_list, drm_mode_compare); |
} |
EXPORT_SYMBOL(drm_mode_sort); |