[PULL] drm-intel-next

Daniel Vetter daniel.vetter at ffwll.ch
Tue Mar 7 00:10:52 UTC 2017


Hi Dave,

Between this one and the drm-misc one I sent out already we have 550+
patches already queued right after -rc1. We're not doing it all wrong :-)

drm-intel-next-2017-03-06:
4 weeks worth of stuff since I was traveling&lazy:

- lspcon improvements (Imre)
- proper atomic state for cdclk handling (Ville)
- gpu reset improvements (Chris)
- lots and lots of polish around fences, requests, waiting and
  everything related all over (both gem and modeset code), from Chris
- atomic by default on gen5+ minus byt/bsw (Maarten did the patch to
  flip the default, really this is a massive joint team effort)
- moar power domains, now 64bit (Ander)
- big pile of in-kernel unit tests for various gem subsystems (Chris),
  including simple mock objects for i915 device and and the ggtt
  manager.
- i915_gpu_info in debugfs, for taking a snapshot of the current gpu
  state. Same thing as i915_error_state, but useful if the kernel didn't
  notice something is stick. From Chris.
- bxt dsi fixes (Umar Shankar)
- bxt w/a updates (Jani)
- no more struct_mutex for gem object unreference (Chris)
- some execlist refactoring (Tvrtko)
- color manager support for glk (Ander)
- improve the power-well sync code to better take over from the
  firmware (Imre)
- gem tracepoint polish (Tvrtko)
- lots of glk fixes all around (Ander)
- ctx switch improvements (Chris)
- glk dsi support&fixes (Deepak M)
- dsi fixes for vlv and clanups, lots of them (Hans de Goede)
- switch to i915.ko types in lots of our internal modeset code (Ander)
- byt/bsw atomic wm update code, yay (Ville)
drm-intel-next-2017-02-06:
First feature pile for 4.12:

- use atomic_commit for legay page flips, once more! (from Maarten)
- piles and piles of fixes and patches to make corner-cases more
  robust in atomic code, execlist, gem, from lots of different folks
- remove pre-production w/a for bxt (Chris)
- taint the kernel on pre-production hw that's no longer supported
  (Chris)
- consistently treat stolen as dma_addr_t (Chris)
- vgpu forcewake cleanup (Weinan Li)
- glk color manager support (Ander)
- explicit fencing support in execbuf, for Android! (Chris)
- ... plus the remaining prep-work for the same (also Chris)
- dp compliance prep (Manasi and Jani)
- cleanup skl/kbl code under IS_GEN9_BC (for "big core"), from Rodrigo

Note that there's a conflict between this and drm-misc-next in
i915_debugfs.c, but it's just entire functions added/removed in the same
place.

Also would be great if you don't delay opening drm-next, I want to
backmerge the entire thing into i915 because we need that there.

Cheers, Daniel


The following changes since commit 64a577196d66b44e37384bc5c4d78c61f59d5b2a:

  lib/Kconfig: make PRIME_NUMBERS not user selectable. (2017-02-24 12:11:21 +1000)

are available in the git repository at:

  git://anongit.freedesktop.org/git/drm-intel tags/drm-intel-next-2017-03-06

for you to fetch changes up to 505b681539a7e14aeb866515d3ef1a67375839bc:

  drm/i915: Update DRIVER_DATE to 20170306 (2017-03-06 08:34:44 +0100)

----------------------------------------------------------------
4 weeks worth of stuff since I was traveling&lazy:

- lspcon improvements (Imre)
- proper atomic state for cdclk handling (Ville)
- gpu reset improvements (Chris)
- lots and lots of polish around fences, requests, waiting and
  everything related all over (both gem and modeset code), from Chris
- atomic by default on gen5+ minus byt/bsw (Maarten did the patch to
  flip the default, really this is a massive joint team effort)
- moar power domains, now 64bit (Ander)
- big pile of in-kernel unit tests for various gem subsystems (Chris),
  including simple mock objects for i915 device and and the ggtt
  manager.
- i915_gpu_info in debugfs, for taking a snapshot of the current gpu
  state. Same thing as i915_error_state, but useful if the kernel didn't
  notice something is stick. From Chris.
- bxt dsi fixes (Umar Shankar)
- bxt w/a updates (Jani)
- no more struct_mutex for gem object unreference (Chris)
- some execlist refactoring (Tvrtko)
- color manager support for glk (Ander)
- improve the power-well sync code to better take over from the
  firmware (Imre)
- gem tracepoint polish (Tvrtko)
- lots of glk fixes all around (Ander)
- ctx switch improvements (Chris)
- glk dsi support&fixes (Deepak M)
- dsi fixes for vlv and clanups, lots of them (Hans de Goede)
- switch to i915.ko types in lots of our internal modeset code (Ander)
- byt/bsw atomic wm update code, yay (Ville)

----------------------------------------------------------------
Ander Conselvan de Oliveira (34):
      drm/i915: Don't leak edid in intel_crt_detect_ddc()
      drm/i915: Don't init hpd polling for vlv and chv from runtime_suspend()
      drm/i915: Fix calculation of rotated x and y offsets for planar formats
      drm/i915: Check for NULL atomic state in intel_crtc_disable_noatomic()
      drm/i915/glk: Turn on workarounds that apply to Geminilake too
      drm/i915: Disable plane gamma in SKL+ sprite planes
      drm/i915/glk: Plane color correction register changes
      drm/i915: Split broadwell_load_luts() into smaller functions
      drm/i915/glk: Program pipe gamma and degamma tables
      drm/i915: Remove WA for swapped HPD pins in broxton A stepping
      drm/i915/dp: Move initialization of hpd_pin to a new function
      drm/i915: Make power domain masks 64 bit long
      drm/i915: Remove unused function intel_ddi_get_link_dpll()
      drm/i915: Convert remaining users of 32bit power domain masks
      drm/i915/glk: Load the degamma LUT even in legacy gamma mode
      drm/i915/glk: Enable pipe CSC
      drm/i915/glk: Fix watermark computations for third sprite plane
      drm/i915/glk: Fix maximum scaling factor for Geminilake scalers
      drm/i915/glk: Pass dev_priv to intel_atomic_setup_scalers()
      drm/i915/glk: Fix Geminilake scalers mode programming
      drm/i915: Store aux power domain in intel_dp
      drm/i915: Store encoder power domain in struct intel_encoder
      drm/i915: Check encoder type in enc_to_dig_port()
      drm/i915/glk: Implement WaDDIIOTimeout
      drm/i915/glk: Don't enable DDI IO power domains during init
      drm/i915: Only enable DDI IO power domains after enabling DPLL
      drm/i915: Enable DDI IO power domains in the DP MST path
      drm/i915: Pass intel_crtc to fdi_link_train() hooks
      drm/i915: Pass intel_crtc to intel_lpt_pch_enable()
      drm/i915: Pass pipe_config to pch_enable() functions
      drm/i915: Pass pipe_config to fdi_link_train() functions
      drm/i915: Pass intel_crtc to DDI functions called from crtc en/disable
      drm/i915: Remove direct usages of intel_crtc->config from DDI code
      drm/i915: Remove duplicate DDI enabling logic from MST path

Andrey Ryabinin (1):
      drm/i915: fix use-after-free in page_flip_completed()

Anusha Srivatsa (1):
      i915/HuC: Add an extra check for platforms that do not have HUC

Arthur Heymans (1):
      drm/i915: Get correct display clock on 945gm

Chris Wilson (238):
      agp/intel: Move intel_fake_agp_sizes into #ifdef block
      drm/i915: Fix W=1 warning for csr_load_work_fn()
      drm/i915: Queue hangcheck when irqs are disabled
      drm/i915: Assert that the kernel_context is hw-id 0
      drm/i915: Assert that the context-switch completion matches our context
      drm/i915: Pevent copying uninitialised garbage into vma->ggtt_view
      drm/i915: Remove disable_lite_restore_wa
      drm/i915: Remove BXT incoherent seqno write workaround
      drm/i915: Remove BXT restore arbitration around ctx switch
      drm/i915: Remove BXT disable pixel mask clamping w/a
      drm/i915: Remove BXT TDL state w/a
      drm/i915: Split intel_engine allocation and initialisation
      drm/i915: Reset the gpu on takeover
      drm/i915: Assert that we don't submit to execlists whilst a preempt is pending
      drm/i915: Only disable execlist preemption for the duration of the request
      drm/i915: Move breadcrumbs irq_posted up a level to engine
      drm/i915: Only run execlist context-switch handler after an interrupt
      drm/i915: Skip the execlists CSB scan and rewrite if the ring is untouched
      drm/i915: Only attempt to pass the first request to execlists
      drm/i915: Dequeue execlists on a new request if any port is available
      drm/i915: Emit dma-fence (and execlists submit) first from signaler
      drm/i915: Move atomic state free from out of fence release
      drm/i915: Remove early pre-production RPS workarounds for BXT
      drm/i915: Report the failure to write to the punit
      drm/i915: Also clear the punit's PDATA sideband register
      drm/i915: Enable userspace to opt-out of implicit fencing
      drm/i915: Support explicit fencing for execbuf
      drm/i915: Make intel_detect_preproduction_hw easier to extend
      drm/i915: Mark the kernel as tainted if we fail the preproduction check
      drm/i915: Add early BXT sdv to the list of preproduction machines
      drm/i915: Record more information about the hanging contexts
      drm/i915: Be defensive when cleaning up i915_gem_internal pages
      drm/i915: Treat stolen memory as DMA addresses
      drm/i915: Sanity check the computed size and base of stolen memory
      drm/i915: Flush untouched framebuffers before display on !llc
      drm/i915/execlists: Skip resetting RING_CONTEXT_STATUS_PTR
      drm/i915/execlists: Add interrupt-pending check to intel_execlists_idle()
      drm/i915: Build DRM range manager selftests for CI
      drm/i915: Recreate internal objects with single page segments if dmar fails
      drm/i915: Reject set-tiling-ioctl with stride==0 and a tiling mode
      drm/i915: Tidy the tail of i915_tiling_ok()
      drm/i915: Allow large objects to be tiled on gen2/3
      drm/i915: Drain the freed state from the tail of the next commit
      drm/i915: Print execlists restart after reset
      drm/i915: Manipulate the Global GTT size using I915_GTT_PAGE_SIZE
      drm/i915: Assign I915_COLOR_UNEVICTABLE to the address space head_node
      drm/i915: Use page coloring to provide the guard page at the end of the GTT
      drm/i915: Mark the end of intel_ring_begin() and check in intel_ring_advance()
      drm/i915: Avoid unguarded reads from the request pointer
      drm/i915: Generate i915_params {} using a macro
      drm/i915: Use bool i915_param.alpha_support
      drm/i915: Capture module parameters for the GPU error state
      drm/i915: Show the current i915_params in debugfs/i915_capabilites
      drm/i915: Remove overzealous fence warn on runtime suspend
      drm/i915: Restore context and pd for ringbuffer submission after reset
      drm/i915: i915_gem_shrink_all() needs an awake device
      drm/i915: Move calling engine->init_hw() to its own function
      drm/i915: Split GEM resetting into 3 phases
      drm/i915: Disable engine->irq_tasklet around resets
      drm/i915: Check for timeout completion when waiting for the rq to submitted
      drm/i915: Assert that we never create a vma for the aliasing_ppgtt
      drm/i915: Use the size/type of address space to make decisions
      drm/i915: Always pin contexts into the high GGTT
      drm/i915/byt: Take powerwell for reading PIPESTAT in debugfs
      drm/i915: Split device release from unload
      drm/i915: Unbind any residual objects/vma from the Global GTT on shutdown
      drm/i915: Flush the freed object queue on device release
      drm/i915: Move the irq_barrier for reset earlier into reset_prepare
      drm/i915: Rename conditional GEM execution macros
      drm/i915: Assert that the active request hasn't been signaled
      drm/i915: Always call i915_gem_reset_finish() following i915_gem_reset_prepare()
      drm/i915: Kill the tasklet then disable
      drm/i915: Park the breadcrumbs signaler across a GPU reset
      drm/i915: Clear the last_retired_context following a hang/reset
      drm/i915: Provide a hook for selftests
      drm/i915: Add some selftests for sg_table manipulation
      drm/i915: Add unit tests for the breadcrumb rbtree, insert/remove
      drm/i915: Add unit tests for the breadcrumb rbtree, completion
      drm/i915: Add unit tests for the breadcrumb rbtree, wakeups
      drm/i915: Mock the GEM device for self-testing
      drm/i915: Mock a GGTT for self-testing
      drm/i915: Mock infrastructure for request emission
      drm/i915: Create a fake object for testing huge allocations
      drm/i915: Add selftests for i915_gem_request
      drm/i915: Add a simple request selftest for waiting
      drm/i915: Add a simple fence selftest to i915_gem_request
      drm/i915: Simple selftest to exercise live requests
      drm/i915: Test simultaneously submitting requests to all engines
      drm/i915: Test request ordering between engines
      drm/i915: Live testing of empty requests
      drm/i915: Add selftests for object allocation, phys
      drm/i915: Add a live seftest for GEM objects
      drm/i915: Test partial mappings
      drm/i915: Test exhaustion of the mmap space
      drm/i915: Test coherency of and barriers between cache domains
      drm/i915: Move uncore selfchecks to live selftest infrastructure
      drm/i915: Test all fw tables during mock selftests
      drm/i915: Sanity check all registers for matching fw domains
      drm/i915: Add some mock tests for dmabuf interop
      drm/i915: Add a live dmabuf selftest
      drm/i915: Add initial selftests for i915_gem_gtt
      drm/i915: Exercise filling the top/bottom portions of the ppgtt
      drm/i915: Exercise filling the top/bottom portions of the global GTT
      drm/i915: Fill different pages of the GTT
      drm/i915: Exercise filling and removing random ranges from the live GTT
      drm/i915: Live testing of lowlevel GTT operations
      drm/i915: Use fault-injection to force the shrinker to run in live GTT tests
      drm/i915: Test creation of VMA
      drm/i915: Exercise i915_vma_pin/i915_vma_insert
      drm/i915: Verify page layout for rotated VMA
      drm/i915: Test creation of partial VMA
      drm/i915: Live testing for context execution
      drm/i915: Extract aliasing ppgtt setup
      drm/i915: Force an aliasing_ppgtt test for context execution
      drm/i915: Initial selftests for exercising eviction
      drm/i915: Add mock exercise for i915_gem_gtt_reserve
      drm/i915: Add mock exercise for i915_gem_gtt_insert
      drm/i915: Add mock tests for GTT/VMA handling
      drm/i915: Exercise manipulate of single pages in the GGTT
      drm/i915: Exercise crossing pot boundaries in the GTT
      drm/i915: Add initial selftests for hang detection and resets
      drm/i915/gvt: Disable access to stolen memory as a guest
      drm/i915: Pass timeout==0 on to i915_gem_object_wait_fence()
      drm/i915: Avoid overflow in computing pot_hole loop termination
      drm/i915: Silence compiler for GTT selftests
      drm/i915: Silence compiler warning for seltests/i915_gem_coherency
      drm/i915/guc: Don't take struct_mutex for object unreference
      drm/i915: The return of i915_gpu_info to debugfs
      drm/i915: Enable fine-tuned RPS for cherryview
      drm/i915: Don't accidentally increase the frequency in handling DOWN rps
      drm/i915: Only apply the jump to the "efficient RPS" frequency on startup
      drm/i915: Micro-optimise i915_get_ggtt_vma_pages()
      drm/i915: Micro-optimise gen6_ppgtt_insert_entries()
      drm/i915: Micro-optimise gen8_ppgtt_insert_entries()
      drm/i915: Don't special case teardown of aliasing_ppgtt
      drm/i915: Split ggtt/alasing_gtt unbind_vma
      drm/i915: Convert clflushed pagetables over to WC maps
      drm/i915: Remove kmap/kunmap wrappers
      drm/i915: Move allocate_va_range to GTT
      drm/i915: Always preallocate gen6/7 ppgtt
      drm/i915: Remove redundant clear of appgtt
      drm/i915: Tidy gen6_write_pde()
      drm/i915: Remove bitmap tracking for used-ptes
      drm/i915: Remove bitmap tracking for used-pdes
      drm/i915: Remove bitmap tracking for used-pdpes
      drm/i915: Remove bitmap tracking for used-pml4
      drm/i915: Remove superfluous posting reads after clear GGTT
      drm/i915: Always mark the PDP as dirty when altered
      drm/i915: Remove defunct GTT tracepoints
      drm/i915: Remove unused ppgtt->enable()
      drm/i915: Remove i915_address_space.start
      drm/i915: Only preallocate the aliasing GTT to the extents of the global GTT
      drm/i915: Differentiate the aliasing_ppgtt with an invalid filp
      drm/i915: Use preferred kernel types in i915_gem_gtt.c
      drm/i915: Only enable hotplug interrupts if the display interrupts are enabled
      drm/i915: Squelch any ktime/jiffie rounding errors for wait-ioctl
      drm/i915: Unwind conversion to i915_gem_phys_ops on failure
      drm/i915: Remove struct_mutex for destroying framebuffers
      drm/i915: struct_mutex is not required for allocating the framebuffer
      drm/i915: Drop struct_mutex around frontbuffer flushes
      drm/i915: Postpone fake breadcrumb interrupt until real interrupts cease
      drm/i915: Break i915_spin_request() if we see an interrupt
      drm/i915: Defer declaration of missed-interrupt until the waiter is asleep
      drm/i915: Only start with the fake-irq timer if interrupts are dead
      drm/i915: Remove completed fences after a wait
      drm/i915: Only apply legacy PDE overflow detection to 3lvl machines
      drm/i915: Remove unneeded struct_mutex around rpm
      drm/i915: Prevent divide-by-zero in debugfs/i915_rps_boost_info
      drm/i915: Move the common RPS warnings to intel_set_rps()
      drm/i915: Store the requested frequency whilst RPS is disabled
      drm/i915: Remove unrequired POSTING_READ from gen6_set_rps()
      drm/i915: Assert that the request->tail is always qword aligned
      drm/i915: Use reservation_object_lock()
      drm/i915: Add i915_param charp macro magic
      drm/i915: Remove change_domain tracepoint
      drm/i915: Move cpu_cache_is_coherent() to header
      drm/i915: Amalgamate flushing of display objects
      drm/i915: Skip clflushes for all non-page backed objects
      drm/i915: Perform object clflushing asynchronously
      drm/i915: Remove 'retire' parameter from intel_fb_obj_flush
      drm/i915: Remove Braswell GGTT update w/a
      Revert "drm/i915/dp: Ratelimit DP aux timeout messages"
      drm/i915: Check against the signaled bit for fences/requests
      drm/i915: Keep a global seqno per-engine
      drm/i915: Move reserve_seqno() next to unreserve_seqno()
      drm/i915: Use a local to shorten req->i915->gpu_error.wait_queue
      drm/i915: Add ourselves to the gpu error waitqueue for the entire wait
      drm/i915: Inline __i915_gem_request_wait_for_execute()
      drm/i915: Deconstruct execute fence
      drm/i915: Protect the request->global_seqno with the engine->timeline lock
      drm/i915: Take a reference whilst processing the signaler request
      drm/i915: Allow a request to be cancelled
      drm/i915: Remove the preempted request from the execution queue
      drm/i915: Exercise request cancellation using a mock selftest
      drm/i915: Replace reset_wait_queue with default_wake_function
      drm/i915: Refactor direct GPU reset from request waiters
      drm/i915: Immediately process a reset before starting waiting
      drm/i915: Remove one level of indention from wait-for-execute
      drm/i915: Suppress fbc suggestion to increase stolen if disabled
      drm/i915/fbdev: Stop repeating tile configuration on stagnation
      drm/i915/execlists: Detect an out-of-order context switch
      drm/i915: Timeout lowlevel_hole GTT selftest early
      drm/i915: Assert all sg are initialised in fake_dma_object for selftests
      drm/i915: Assert we do not overflow 4lvl page directories
      drm/i915: Sanity check the vma->node prior to binding into the GTT
      drm/i915: Advance start address on crossing PML (48b ppgtt) boundary
      drm/i915: Only unwind the local pgtable layer if empty
      drm/i915: Unwind vma->pages allocation upon failure
      drm/i915: Remove the vma from the drm_mm if binding fails
      drm/i915: Remove redundant TLB invalidate on switching contexts
      drm/i915: Remove redundant TLB invalidate on switching ppgtt
      drm/i915: Reduce context alignment
      drm/i915: Distinguish between timeout and error in sideband transactions
      drm/i915: Report both waiters and success from intel_engine_wakeup()
      drm/i915: Signal first fence from irq handler if complete
      drm/i915: Defer enabling hangcheck to the first fake breadcrumb interrupt
      drm/i915: Delay disabling the user interrupt for breadcrumbs
      drm/i915: Consolidate reporting of "missed breadcrumbs"
      drm/i915/guc: Make wq_lock irq-safe
      drm/i915/guc: Reorder __i915_guc_submit to reduce spinlock holdtime
      drm/i915: Tighten mmio arrays for MIPI_PORT
      drm/i915: Fix all intel_framebuffer_init failures to take the error path
      drm/i915: Prevent concurrent tiling/framebuffer modifications
      drm/i915: Move w/a LRI debug message from context-init to driver load
      drm/i915: Hold rpm during GEM suspend in driver unload/suspend
      drm/i915: Restore the invalid access without RPM warning
      drm/i915: Assert that fence->lock is held in an irq-safe manner
      drm/i915: s/assert_spin_locked/lockdep_assert_held/
      drm/i915/guc: Disable irq for __i915_guc_submit wq_lock
      drm/i915: Include GT/seqno activity in engine/hangcheck debugfs
      drm/i915: Include power-management state in gpu error dump
      drm/i915: Drop spinlocks around adding to the client request list
      drm/i915: Differentiate between hangcheck waiting for timer or scheduler
      drm/i915: Ensure the engine is idle before manually changing HWS
      drm/i915: Generalise wait for execlists to be idle
      drm/i915: Take reference for signaling the request from hardirq
      drm/i915: Refactor wakeup of the next breadcrumb waiter
      drm/i915: Split breadcrumbs spinlock into two

Chuanxiao Dong (1):
      drm/i915/gvt: set ring buffer size to default for guc submission

Daniel Vetter (5):
      Merge remote-tracking branch 'airlied/drm-next' into drm-intel-next-queued
      drm/i915: Update DRIVER_DATE to 20170206
      Merge remote-tracking branch 'airlied/drm-next' into drm-intel-next-queued
      Merge airlied/drm-next into drm-misc-next
      drm/i915: Update DRIVER_DATE to 20170306

Daniele Ceraolo Spurio (2):
      drm/i915: fix pm refcounting on fence error in execbuf
      drm/i915: refactor register fw read/write macros for recent GENs

Deepak M (7):
      drm/i915: Set the Z inversion overlap field
      drm/i915/glk: Program dphy param reg for GLK
      drm/i915/glk: Program new MIPI DSI PHY registers for GLK
      drm/i915/glk: Add DSI PLL divider range for glk
      drm/i915i/glk: Program MIPI_CLOCK_CTRL only for BXT
      drm/i915/glk: Program txesc clock divider for GLK
      drm/i915/glk: Add MIPIIO Enable/disable sequence

Deepak S (1):
      drm/i915/chv: Set min freq to RPn on CHV.

Geliang Tang (1):
      drm/i915/error: use rb_entry()

Hans de Goede (17):
      drm/i915: Fix not finding the VBT when it overlaps with OPREGION_ASLE_EXT
      drm/i915/dsi: Move calling of wait_for_dsi_fifo_empty to mipi_exec_send_packet
      drm/i915/dsi: Merge intel_dsi_disable/enable into their respective callers
      drm/i915/dsi: Add intel_dsi_unprepare() helper
      drm/i915/dsi: Move intel_dsi_clear_device_ready()
      drm/i915/dsi: Make intel_dsi_enable/disable directly exec VBT sequences
      drm/i915/dsi: VLV/CHT Only wait for LP00 on MIPI PORT A
      drm/i915/dsi: Document the panel enable / disable sequences from the spec
      drm/i915/dsi: Drop bogus MIPI_SEQ_ASSERT_RESET before POWER_ON
      drm/i915/dsi: Move MIPI_SEQ_POWER_ON/OFF calls together with pmic gpio calls
      drm/i915/dsi: Group DPOunit clock gate workaround with PLL enable
      drm/i915/dsi: Execute MIPI_SEQ_DEASSERT_RESET before calling device_ready()
      drm/i915/dsi: Group MIPI_SEQ_BACKLIGHT_ON/OFF with panel_[en|dis]able_backlight
      drm/i915/dsi: Document always using v3 SHUTDOWN / MIPI_SEQ_DISPLAY_OFF order
      drm/i915/dsi: Execute MIPI_SEQ_TEAR_OFF from intel_dsi_post_disable
      drm/i915/dsi: Call MIPI_SEQ_TEAR_ON and DISPLAY_ON for cmd-mode (untested)
      drm/i915/dsi: Skip delays for v3 VBTs in vid-mode

Imre Deak (11):
      drm/i915/gen9+: Enable hotplug detection early
      drm/i915/lspcon: Fix resume time initialization due to unasserted HPD
      drm/i915/lspcon: Remove DPCD compare based resume time workaround
      drm/i915/gen5+, pch: Enable hotplug detection early
      drm/i915: Remove redundant toggling from the power well sync_hw hooks
      drm/i915: Call the sync_hw hook for power wells without a domain
      drm/i915/gen9: Fix clearing of the BIOS power well request register
      drm/i915: Preserve the state of power wells not explicitly enabled
      drm/i915: Add power well SW/HW state verification
      drm/i915/lspcon: Switch back to PCON mode after output replug
      drm/i915/gen9: Increase PCODE request timeout to 50ms

Jani Nikula (9):
      drm/i915/dp: do not proceed with autotests if we don't ACK them
      drm/color: un-inline drm_color_lut_extract()
      Revert "drm/color: un-inline drm_color_lut_extract()"
      drm/i915: use variadic macros and arrays to choose port/pipe based registers
      drm/i915: don't warn about Skylake CPU - KabyPoint PCH combo
      drm/i915/bxt: apply clock gating workaround to all revisions
      drm/i915/bxt: remove snooping workaround on old A revisions
      drm/i915/bxt: remove WaRsDisableCoarsePowerGating for early BXT
      drm/i915: use BUILD_BUG_ON to ensure platform name has been set up

Joonas Lahtinen (3):
      drm/i915: Avoid BIT(max) - 1 and use GENMASK(max - 1, 0)
      drm/i915: Use for_each_power_domain() in i915_power_domain_info()
      drm/i915: Add __destroy_hw_context

Juergen Gross (1):
      drm/i915: fix i915 running as dom0 under Xen

Kelvin Gardiner (1):
      drm/i915/bdw: Do not write the replay bit of the ring mode register

Kenneth Graunke (1):
      drm/i915: Drop support for I915_EXEC_CONSTANTS_* execbuf parameters.

Lee, Shawn C (1):
      drm/i915/bxt: Add MST support when do DPLL calculation

Lyude (2):
      drm/i915/debugfs: Add i915_hpd_storm_ctl
      drm/i915/dp: Ratelimit DP aux timeout messages

Maarten Lankhorst (4):
      drm/i915: Use atomic page flip for intel again.
      drm/i915: Disable all crtcs during driver unload, v2.
      drm/i915: Fix POWER_DOMAIN_AUDIO refcounting.
      drm/i915: Enable atomic support by default on supported platforms.

Madhav Chauhan (2):
      drm/i915/glk: Validate only DSI PORT A PLL divider
      drm/i915/glk: Fix DSI enable I/O sequence

Manasi Navare (5):
      drm/i915: Add support for DP link training compliance
      drm/i915: Fixes to support DP Compliance EDID tests
      drm: Add definitions for DP compliance Video pattern tests
      drm/i915: Add support for DP Video pattern compliance tests
      drm/i915/dp: Reset the link params on HPD/connected boot/resume

Matthew Auld (1):
      drm/i915: remove 512GB allocation warning

Michal Wajdeczko (1):
      drm/i915: Don't use enums for hardware engine id

Michał Winiarski (2):
      drm/i915: Always convert incoming exec offsets to non-canonical
      drm/i915/skl: Add missing SKL ID

Mika Kuoppala (7):
      drm/i915: Create context desc template when context is created
      drm/i915: Avoid tweaking evaluation thresholds on Baytrail v3
      drm/i915/gtt: Make I915_PDPES_PER_PDP inline function
      drm/i915: Don't mark pdps clear if pdps are not submitted
      drm/i915/gtt: Prefer i915_vm_is_48bit() over macro
      drm/i915: Avoid using word legacy with ppgtt
      drm/i915/gtt: Setup vm callbacks late

Paulo Zanoni (2):
      x86/gpu: GLK uses the same GMS values as SKL
      drm/i915: make i915_stolen_to_physical() return phys_addr_t

Robert Bragg (1):
      drm/i915: fix for WaDisableDopClockGating:bdw

Rodrigo Vivi (3):
      drm/i915/kbl: Apply WaIncreaseDefaultTLBEntries on KBL.
      drm/i915: Introduce IS_GEN9_BC for Skylake and Kabylake.
      drm/i915: DMC 1.03 for Geminilake

Tvrtko Ursulin (19):
      drm/i915/guc: Log significant events at the info level
      drm/i915: Emit to ringbuffer directly
      drm/i915: Fix uninitialized return from mi_set_context
      drm/i915: Remove duplicate intel_logical_ring_workarounds_emit
      drm/i915: Make int __intel_ring_space static
      drm/i915: Simplify cleanup path in intel_engines_init
      drm/i915: Move common workaround code to intel_engine_cs
      drm/i915: Tidy workaround batch buffer emission
      drm/i915: Consolidate gen8_emit_pipe_control
      drm/i915: Fix typo in semaphore debug message
      drm/i915: Tidy execlists_init_reg_state
      drm/i915/tracepoints: Tidy request event class
      drm/i915/tracepoints: Adjust i915_gem_ring_dispatch
      drm/i915/tracepoints: Tidy i915_gem_request_wait_begin
      drm/i915/tracepoints: Remove unused i915_gem_request_complete
      drm/i915/tracepoints: Add request submit and execute tracepoints
      drm/i915/tracepoints: Rename i915_gem_request_notify
      drm/i915/tracepoints: Add backend level request in and out tracepoints
      drm/i915/tracepoints: Add hw_id to context tracepoints

Uma Shankar (5):
      drm/i915: Add MIPI_IO WA and program DSI regulators
      drm/i915: Check for platform specific GPIO config
      drm/i915: Fix PLL 8x/3 divider for MIPI video mode
      drm/i915/bxt: Fix BXT DSI ULPS sequence
      drm/i915/bxt: Disable device ready before shutdown command

Ville Syrjälä (40):
      drm/i915: Store the pipe pixel rate in the crtc state
      drm/i915: Nuke intel_mode_max_pixclk()
      drm/i915: s/get_display_clock_speed/get_cdclk/
      drm/i915: Clean up the .get_cdclk() assignment if ladder
      drm/i915: Move most cdclk/rawclk related code to intel_cdclk.c
      drm/i915: Pass computed vco to bxt_set_cdclk()
      drm/i915: Start moving the cdclk stuff into a distinct state structure
      drm/i915: Track full cdclk state for the logical and actual cdclk frequencies
      drm/i915: Pass dev_priv to remainder of the cdclk functions
      drm/i915: Pass the cdclk state to the set_cdclk() functions
      drm/i915: Move PFI credit reprogramming into vlv/chv_set_cdclk()
      drm/i915: Nuke the VLV/CHV PFI programming power domain workaround
      drm/i915: Replace the .modeset_commit_cdclk() hook with a more direct .set_cdclk() hook
      drm/i915: Move ilk_pipe_pixel_rate() to intel_display.c
      drm/i915: Avoid spurious WARNs about the wrong pipe in the PPS code
      drm/i915: Simplify platform checks in intel_fb_pitch_limit()
      drm/i915: Dump more configuration information for DSI
      drm/i915: Refactor code to select the DDI buf translation table
      drm/i915: Refactor translate_signal_level()
      drm/i915: Introduce intel_ddi_dp_voltage_max()
      drm/i915: Fix legacy cursor vs. watermarks for ILK-BDW
      drm/i915: Do .init_clock_gating() earlier to avoid it clobbering watermarks
      drm/i915: Track visible planes in a bitmask
      drm/i915: Track plane fifo sizes under intel_crtc
      drm/i915: Move vlv wms from crtc->wm_state to crtc->wm.active.vlv
      drm/i915: Plop vlv wm state into crtc_state
      drm/i915: Plop vlv/chv fifo sizes into crtc state
      drm/i915: Compute VLV/CHV FIFO sizes based on the PM2 watermarks
      drm/i915: Compute vlv/chv wms the atomic way
      drm/i915: Skip useless watermark/FIFO related work on VLV/CHV when not needed
      drm/i915: Compute proper intermediate wms for vlv/cvh
      drm/i915: Nuke crtc->wm.cxsr_allowed
      drm/i915: Only use update_wm_{pre,post} for pre-ilk platforms
      drm/i915: Sanitize VLV/CHV watermarks properly
      drm/i915: Workaround VLV/CHV sprite1->sprite0 enable underrun
      drm/i915: Kill level 0 wm hack for VLV/CHV
      drm/i915: Add plane update/disable tracepoints
      drm/i915: Add VLV/CHV watermark/FIFO programming tracepoints
      drm/i915: Add cxsr toggle tracepoint
      drm/i915: Add FIFO underrun tracepoints

Weinan Li (2):
      drm/i915: noop forcewake get/put when vgpu activated
      drm/i915: clean up unused vgpu_read/write

Zhi Wang (2):
      drm/i915: Let execlist_update_context() cover !FULL_PPGTT mode.
      drm/i915: A hotfix for making aliasing PPGTT work for GVT-g

sagar.a.kamble at intel.com (1):
      drm/i915: Do RPM Wake during GuC/HuC status read

 Documentation/gpu/i915.rst                         |    9 +
 arch/x86/kernel/early-quirks.c                     |    1 +
 drivers/char/agp/intel-gtt.c                       |   16 +-
 drivers/gpu/drm/i915/Kconfig                       |    1 +
 drivers/gpu/drm/i915/Kconfig.debug                 |   29 +
 drivers/gpu/drm/i915/Makefile                      |    5 +
 drivers/gpu/drm/i915/gvt/cmd_parser.c              |   36 +-
 drivers/gpu/drm/i915/i915_debugfs.c                |  364 ++-
 drivers/gpu/drm/i915/i915_drv.c                    |  109 +-
 drivers/gpu/drm/i915/i915_drv.h                    |  231 +-
 drivers/gpu/drm/i915/i915_gem.c                    |  359 ++-
 drivers/gpu/drm/i915/i915_gem.h                    |    9 +
 drivers/gpu/drm/i915/i915_gem_batch_pool.c         |    4 +-
 drivers/gpu/drm/i915/i915_gem_clflush.c            |  189 ++
 drivers/gpu/drm/i915/i915_gem_clflush.h            |   37 +
 drivers/gpu/drm/i915/i915_gem_context.c            |  163 +-
 drivers/gpu/drm/i915/i915_gem_context.h            |    2 -
 drivers/gpu/drm/i915/i915_gem_dmabuf.c             |    5 +
 drivers/gpu/drm/i915/i915_gem_evict.c              |   16 +-
 drivers/gpu/drm/i915/i915_gem_execbuffer.c         |  159 +-
 drivers/gpu/drm/i915/i915_gem_gtt.c                | 2086 ++++++--------
 drivers/gpu/drm/i915/i915_gem_gtt.h                |  124 +-
 drivers/gpu/drm/i915/i915_gem_internal.c           |    7 +-
 drivers/gpu/drm/i915/i915_gem_object.h             |   41 +-
 drivers/gpu/drm/i915/i915_gem_request.c            |  499 ++--
 drivers/gpu/drm/i915/i915_gem_request.h            |   91 +-
 drivers/gpu/drm/i915/i915_gem_shrinker.c           |    7 +-
 drivers/gpu/drm/i915/i915_gem_stolen.c             |   42 +-
 drivers/gpu/drm/i915/i915_gem_tiling.c             |   25 +-
 drivers/gpu/drm/i915/i915_gem_timeline.h           |    9 +-
 drivers/gpu/drm/i915/i915_gpu_error.c              |  321 ++-
 drivers/gpu/drm/i915/i915_guc_submission.c         |   37 +-
 drivers/gpu/drm/i915/i915_irq.c                    |  179 +-
 drivers/gpu/drm/i915/i915_params.c                 |    6 +-
 drivers/gpu/drm/i915/i915_params.h                 |   81 +-
 drivers/gpu/drm/i915/i915_pci.c                    |   32 +-
 drivers/gpu/drm/i915/i915_perf.c                   |    2 +-
 drivers/gpu/drm/i915/i915_reg.h                    |  102 +-
 drivers/gpu/drm/i915/i915_selftest.h               |  106 +
 drivers/gpu/drm/i915/i915_sysfs.c                  |   35 +-
 drivers/gpu/drm/i915/i915_trace.h                  |  472 ++-
 drivers/gpu/drm/i915/i915_utils.h                  |   11 +
 drivers/gpu/drm/i915/i915_vgpu.c                   |    9 +-
 drivers/gpu/drm/i915/i915_vma.c                    |   91 +-
 drivers/gpu/drm/i915/i915_vma.h                    |    4 +-
 drivers/gpu/drm/i915/intel_atomic.c                |   15 +-
 drivers/gpu/drm/i915/intel_atomic_plane.c          |   17 +-
 drivers/gpu/drm/i915/intel_audio.c                 |    4 +-
 drivers/gpu/drm/i915/intel_breadcrumbs.c           |  528 ++--
 drivers/gpu/drm/i915/intel_cdclk.c                 | 1891 ++++++++++++
 drivers/gpu/drm/i915/intel_color.c                 |  104 +-
 drivers/gpu/drm/i915/intel_crt.c                   |   21 +-
 drivers/gpu/drm/i915/intel_csr.c                   |    8 +-
 drivers/gpu/drm/i915/intel_ddi.c                   |  449 +--
 drivers/gpu/drm/i915/intel_device_info.c           |    8 +-
 drivers/gpu/drm/i915/intel_display.c               | 3029 +++++---------------
 drivers/gpu/drm/i915/intel_dp.c                    |  307 +-
 drivers/gpu/drm/i915/intel_dp_mst.c                |   37 +-
 drivers/gpu/drm/i915/intel_dpll_mgr.c              |   54 +-
 drivers/gpu/drm/i915/intel_dpll_mgr.h              |   16 -
 drivers/gpu/drm/i915/intel_drv.h                   |  198 +-
 drivers/gpu/drm/i915/intel_dsi.c                   |  562 +++-
 drivers/gpu/drm/i915/intel_dsi.h                   |    5 +
 drivers/gpu/drm/i915/intel_dsi_panel_vbt.c         |   89 +-
 drivers/gpu/drm/i915/intel_dsi_pll.c               |  135 +-
 drivers/gpu/drm/i915/intel_dvo.c                   |    1 +
 drivers/gpu/drm/i915/intel_engine_cs.c             |  686 ++++-
 drivers/gpu/drm/i915/intel_fbc.c                   |   11 +-
 drivers/gpu/drm/i915/intel_fbdev.c                 |   76 +-
 drivers/gpu/drm/i915/intel_fifo_underrun.c         |   25 +-
 drivers/gpu/drm/i915/intel_frontbuffer.c           |    3 +-
 drivers/gpu/drm/i915/intel_frontbuffer.h           |    8 +-
 drivers/gpu/drm/i915/intel_guc_loader.c            |   23 +-
 drivers/gpu/drm/i915/intel_hangcheck.c             |    4 +
 drivers/gpu/drm/i915/intel_hdmi.c                  |   17 +-
 drivers/gpu/drm/i915/intel_hotplug.c               |   31 +-
 drivers/gpu/drm/i915/intel_huc.c                   |   15 +-
 drivers/gpu/drm/i915/intel_i2c.c                   |    4 +-
 drivers/gpu/drm/i915/intel_lrc.c                   |  880 ++----
 drivers/gpu/drm/i915/intel_lrc.h                   |    3 -
 drivers/gpu/drm/i915/intel_lspcon.c                |   17 +-
 drivers/gpu/drm/i915/intel_lvds.c                  |    8 +-
 drivers/gpu/drm/i915/intel_mocs.c                  |   55 +-
 drivers/gpu/drm/i915/intel_overlay.c               |   79 +-
 drivers/gpu/drm/i915/intel_panel.c                 |    4 +-
 drivers/gpu/drm/i915/intel_pipe_crc.c              |    2 +-
 drivers/gpu/drm/i915/intel_pm.c                    |  919 +++---
 drivers/gpu/drm/i915/intel_ringbuffer.c            | 1147 ++------
 drivers/gpu/drm/i915/intel_ringbuffer.h            |  174 +-
 drivers/gpu/drm/i915/intel_runtime_pm.c            |  625 ++--
 drivers/gpu/drm/i915/intel_sdvo.c                  |    1 +
 drivers/gpu/drm/i915/intel_sideband.c              |   34 +-
 drivers/gpu/drm/i915/intel_sprite.c                |   17 +-
 drivers/gpu/drm/i915/intel_tv.c                    |    1 +
 drivers/gpu/drm/i915/intel_uncore.c                |  166 +-
 drivers/gpu/drm/i915/selftests/huge_gem_object.c   |  135 +
 drivers/gpu/drm/i915/selftests/huge_gem_object.h   |   45 +
 .../gpu/drm/i915/selftests/i915_gem_coherency.c    |  385 +++
 drivers/gpu/drm/i915/selftests/i915_gem_context.c  |  459 +++
 drivers/gpu/drm/i915/selftests/i915_gem_dmabuf.c   |  303 ++
 drivers/gpu/drm/i915/selftests/i915_gem_evict.c    |  260 ++
 drivers/gpu/drm/i915/selftests/i915_gem_gtt.c      | 1556 ++++++++++
 drivers/gpu/drm/i915/selftests/i915_gem_object.c   |  600 ++++
 drivers/gpu/drm/i915/selftests/i915_gem_request.c  |  882 ++++++
 .../gpu/drm/i915/selftests/i915_live_selftests.h   |   19 +
 .../gpu/drm/i915/selftests/i915_mock_selftests.h   |   20 +
 drivers/gpu/drm/i915/selftests/i915_random.c       |   63 +
 drivers/gpu/drm/i915/selftests/i915_random.h       |   50 +
 drivers/gpu/drm/i915/selftests/i915_selftest.c     |  250 ++
 drivers/gpu/drm/i915/selftests/i915_vma.c          |  746 +++++
 drivers/gpu/drm/i915/selftests/intel_breadcrumbs.c |  481 ++++
 drivers/gpu/drm/i915/selftests/intel_hangcheck.c   |  537 ++++
 drivers/gpu/drm/i915/selftests/intel_uncore.c      |  182 ++
 drivers/gpu/drm/i915/selftests/mock_context.c      |   78 +
 drivers/gpu/drm/i915/selftests/mock_context.h      |   34 +
 drivers/gpu/drm/i915/selftests/mock_dmabuf.c       |  176 ++
 drivers/gpu/drm/i915/selftests/mock_dmabuf.h       |   41 +
 drivers/gpu/drm/i915/selftests/mock_drm.c          |   54 +
 drivers/gpu/drm/i915/selftests/mock_drm.h          |   31 +
 drivers/gpu/drm/i915/selftests/mock_engine.c       |  207 ++
 drivers/gpu/drm/i915/selftests/mock_engine.h       |   54 +
 drivers/gpu/drm/i915/selftests/mock_gem_device.c   |  226 ++
 drivers/gpu/drm/i915/selftests/mock_gem_device.h   |    9 +
 drivers/gpu/drm/i915/selftests/mock_gem_object.h   |    8 +
 drivers/gpu/drm/i915/selftests/mock_gtt.c          |  138 +
 drivers/gpu/drm/i915/selftests/mock_gtt.h          |   35 +
 drivers/gpu/drm/i915/selftests/mock_request.c      |   63 +
 drivers/gpu/drm/i915/selftests/mock_request.h      |   46 +
 drivers/gpu/drm/i915/selftests/scatterlist.c       |  355 +++
 include/drm/drm_dp_helper.h                        |   57 +
 include/drm/i915_pciids.h                          |    3 +-
 include/uapi/drm/i915_drm.h                        |   65 +-
 tools/testing/selftests/drivers/gpu/i915.sh        |    1 +
 133 files changed, 18969 insertions(+), 8361 deletions(-)
 create mode 100644 drivers/gpu/drm/i915/i915_gem_clflush.c
 create mode 100644 drivers/gpu/drm/i915/i915_gem_clflush.h
 create mode 100644 drivers/gpu/drm/i915/i915_selftest.h
 create mode 100644 drivers/gpu/drm/i915/intel_cdclk.c
 create mode 100644 drivers/gpu/drm/i915/selftests/huge_gem_object.c
 create mode 100644 drivers/gpu/drm/i915/selftests/huge_gem_object.h
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_gem_coherency.c
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_gem_context.c
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_gem_dmabuf.c
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_gem_evict.c
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_gem_gtt.c
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_gem_object.c
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_gem_request.c
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_live_selftests.h
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_mock_selftests.h
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_random.c
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_random.h
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_selftest.c
 create mode 100644 drivers/gpu/drm/i915/selftests/i915_vma.c
 create mode 100644 drivers/gpu/drm/i915/selftests/intel_breadcrumbs.c
 create mode 100644 drivers/gpu/drm/i915/selftests/intel_hangcheck.c
 create mode 100644 drivers/gpu/drm/i915/selftests/intel_uncore.c
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_context.c
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_context.h
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_dmabuf.c
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_dmabuf.h
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_drm.c
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_drm.h
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_engine.c
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_engine.h
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_gem_device.c
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_gem_device.h
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_gem_object.h
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_gtt.c
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_gtt.h
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_request.c
 create mode 100644 drivers/gpu/drm/i915/selftests/mock_request.h
 create mode 100644 drivers/gpu/drm/i915/selftests/scatterlist.c

-- 
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch


More information about the dri-devel mailing list