Hi Mark, Thanks for your comments. On 02/12/2013 11:39 AM, Mark Rutland wrote: > Hello, > > I have a few comments on the devicetree binding and the way it's parsed. > >> +static const struct of_device_id dbx500_mailbox_match[] = { >> + { .compatible = "stericsson,db8500-mailbox", >> + .data = (void *)db8500_mboxes, >> + }, >> + { .compatible = "stericsson,db9540-mailbox", >> + .data = (void *)dbx540_mboxes, >> + }, >> + { /* sentinel */} >> +}; >> + > > The binding for the compatible strings above and property parsing below should > be documented. > Yes you're right. I will add a description in Documentation/devicetree/bindings/mailbox/... >> +static int dbx500_mbox_probe(struct platform_device *pdev) >> +{ >> + const struct platform_device_id *platid = platform_get_device_id(pdev); >> + struct resource *mem; >> + int ret, i, legacy_offset = 0, upap_offset; >> + struct mailbox **list; >> + int irq; >> + struct dbx500_plat_data *pdata = dev_get_platdata(&pdev->dev); >> + struct device_node *np = pdev->dev.of_node; >> + >> + if (!pdata) { >> + if (np) { >> + of_property_read_u32(np, "legacy-offset", >> +&legacy_offset); > > I see that legacy_offset is initialised to 0, and there's no check on the > return value of of_property_read_u32. Does that mean this is an optional > property? This needs to be documented. > Correct, I'll add a check. This offset must be compared to shared memory size. >> + of_property_read_u32(np, "upap-offset",&upap_offset); > > However, upap_offset isn't initialised, but there's no check on the return > value. If "upap-offset" isn't defined in the dt, upap_offset won't have been > initialised. Should be documented too. upap_offset is optional since not supported by all STE platforms. Anyway, value must be checked when used. > > Is there no basic sanity checking that could be done here? I assume there's a > maximum offset we expect that's less than 4GB? > > Additionally, of_property_read_u32 takes a *u32, not *int. It would be nice to > be consistent with the interface. OK > > I'm not familiar with the hardware. What's the difference between the legacy > and upap cases? Same HW, but different way to access and manage shared memory. Link to coprocessor firmware version. > >> + list = (struct mailbox **)of_match_device( >> + dbx500_mailbox_match,&pdev->dev)->data; >> + if (!list) { >> + /* No mailbox configuration */ >> + dev_err(&pdev->dev, "No configuration found\n"); >> + return -ENODEV; >> + } >> + } else { >> + /* No mailbox configuration */ >> + dev_err(&pdev->dev, "No configuration found\n"); >> + return -ENODEV; >> + } >> + } else { >> + list = (struct mailbox **)platid->driver_data; >> + legacy_offset = pdata->legacy_offset; >> + upap_offset = pdata->upap_offset; >> + } >> + >> + mem = platform_get_resource_byname(pdev, IORESOURCE_MEM, "prcm_reg"); > > Does this work for dt? I wasn't aware we got anything more than anonymous > memory and interrupts. > Yes this is working with and without dt. dt declaration will be the following mailbox { compatible = "stericsson,db8500-mailbox"; reg = <0x80157000 0x1000>, <0x801B8000 0x2000>; reg-names = "prcm-reg", "prcmu-tcdm"; interrupts = <0 47 0x4>; interrupt-names = "irq"; legacy-offset = <0xdd4>; }; >> + mbox_base = devm_ioremap(&pdev->dev, mem->start, resource_size(mem)); >> + if (!mbox_base) { >> + ret = -ENOMEM; >> + goto out; >> + } >> + >> + mem = platform_get_resource_byname(pdev, IORESOURCE_MEM, "prcmu_tcdm"); > > Same here. > > Thanks, > Mark. > Regards, Loic-- 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