On Tue, Feb 22, 2011 at 1:25 AM, Ramirez Luna, Omar <omar.ramirez@xxxxxx> wrote: > Hi, > > On Mon, Feb 21, 2011 at 3:12 PM, David Cohen <dacohen@xxxxxxxxx> wrote: >> Generic errors codes make easier to threat possible IOMMU users which >> have (partially or totally) common drivers for different OMAP >> versions. > > Agree then. Good we agreed on that. > >>>> + Â Â Â /* Fault callback or TLB/PTE Dynamic loading */ >>>> + Â Â Â if (obj->isr && !obj->isr(obj, da, errs, obj->isr_priv)) >>>> Â Â Â Â Â Â Â Âreturn IRQ_HANDLED; >>> >>> BTW, why not changing the name isr for cb, it is confusing since there >>> is another fault_isr called by mmu, AFAIK nobody uses obj->isr >> >> The main purpose of this function is to be an ISR, not only callback. > > Yep, I just thought it was a bit too much of: > (1) The real isr: iommu_fault_handler, set on request_irq > (2) A plugged fault_isr for mach specific code: omap2_iommu_fault_isr, > for error reporting. > (3) And then a plugged custom isr, to be set by the user. > > Feel free to ignore. (1) does nothing but to call (2) and then (3) if it exists and print error message. (2) as you said, it's mach specific and necessary for the generic upper layer. (3) does what the IOMMU user wants and may replace (1) if it returns 0. They belong to different layers and should coexist. > >>> So I think the following will be bad practice: >>> >>> Â Â Â Âmmu = iommu_get("iva2"); >>> Â Â Â Âif (!IS_ERR(mmu)) >>> Â Â Â Â Â Â Â Âmmu->isr = mmu_fault_callback; >>> >>> Shall we think anything to prevent such mis-usage? >> >> Well, the IOMMU user has access to IOMMU obj, so it can not only >> change the (*isr)() but to mess with a lot of other stuff. The only >> way to prevent it is to avoid user to have obj. But then, this fix (or >> issue) does not belong to this patch. > > Agree, just pointing out. That's a valid point, but it requires an intrusive approach to prevent such mis-usage. For now we must trust the user won't mess with obj. Br, David > > Regards, > > Omar > -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html