On Fri, 15 Jun 2018 19:46:50 +0100, Vicente Bergas <vicencb at gmail.com> wrote: > > On Fri, Jun 15, 2018 at 6:51 PM, Marc Zyngier <marc.zyngier at arm.com> wrote: > > On 15/06/18 17:39, Vicente Bergas wrote: > >> On Wed, Jun 13, 2018 at 12:46 PM, JeffyChen <jeffy.chen at rock-chips.com> wrote: > >>> Hi Marc & Vicente, > >>> > >>> On 06/13/2018 06:26 PM, Marc Zyngier wrote: [...] > >> I can confirm that rockchip_drm_platform_shutdown works as fine as > >> rockchip_drm_platform_remove. > >> Just a note: The first time I noticed this error was because it > >> appeared on display, now that the display is off, are we sure the > >> error is fixed? > >> Also, could there be other peripherals that need to be powered off > >> before the iommu? > >> For curiosity: why is the iommu disabled before kexec instead of > >> resetting it after kexec? > > > > Because by the time you're in the new kernel, you've corrupted the page > > tables, accessed peripheral address space, and set the system on fire. > > > > In general, having a DMA master active across something like kexec is a > > pretty fatal issue. And when your boot loader is a Linux kernel using > > kexec, you're really insisting that kexec works correctly. > > Is it feasible to place the display memory at a virtual address that > matches the physical address? That depends on the addressing capability of the end-point, and on the kernel ability to allocate a large, contiguous range of physical memory. I'm not sure it is worth the hassle just to get the display working all the way through shutdown (knowing that the most likely event after that is a power off). M. -- Jazz is not dead, it just smell funny.