On 27.11.2012 09:33, Dave Airlie wrote: >> Third would be having a firewall in 2D driver checking the stream and >> ensuring all registers that accept addresses are written by values >> derived from dmabufs. I haven't tried implementing this, but it'd >> involve a lookup table in kernel and CPU reading through the command >> stream. Offsets and sizes would also need to be validated. There would >> be a performance hit. > > This is the standard mechanism, and what exynos does as well. > > The per process VM method is also used as an extension to this on some hw. Hi, Thanks for the pointer, I looked at exynos code. It indeed checks the registers written to, but it doesn't prevent overrun by checking sizes of buffers and compare against requests. Based on my experience with Tegra graphics stack, going through command streams in kernel is bad for performance. For 2D operations this is probably ok as the command streams are pretty simple. Anything more complex is going to cause severe degradation of performance, but it's also outside the scope of this patch set. If this is the way to go, I'll put the firewall behind a Kconfig flag so that system integrator can decide if his system needs it. Terje -- To unsubscribe from this list: send the line "unsubscribe linux-tegra" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html