Hi Murali, On 03/27/2018 11:31 AM, Murali Karicheri wrote: > Navigator Subsystem (NSS) available on K2G SoC has a cut down > version of QMSS with less number of queues, internal linking ram > with lesser number of buffers etc. It doesn't have status and > explicit push register space as in QMSS available on other K2 SoCs. > So define reg indices specific to QMSS on K2G. This patch introduces > "keystone-navigator-qmss-l" compatibility to identify QMSS on > K2G NSS (QMSS Lite) and to customize the dts handling code. Per > Device manual, descriptors with index less than or equal to > regions0_size is in region 0 in the case of QMSS where as for > QMSS Lite, descriptors with index less than regions0_size is in > region 0. So update the size accordingly in the regions0_size bits > of the linking ram size 0 register. > > Signed-off-by: Murali Karicheri <m-karicheri2@xxxxxx> > Signed-off-by: WingMan Kwok <w-kwok2@xxxxxx> > --- > .../bindings/soc/ti/keystone-navigator-qmss.txt | 7 ++ > drivers/soc/ti/knav_qmss.h | 6 ++ > drivers/soc/ti/knav_qmss_queue.c | 90 ++++++++++++++++------ > 3 files changed, 81 insertions(+), 22 deletions(-) > > diff --git a/Documentation/devicetree/bindings/soc/ti/keystone-navigator-qmss.txt b/Documentation/devicetree/bindings/soc/ti/keystone-navigator-qmss.txt > index 77cd42c..1b0878a 100644 > --- a/Documentation/devicetree/bindings/soc/ti/keystone-navigator-qmss.txt > +++ b/Documentation/devicetree/bindings/soc/ti/keystone-navigator-qmss.txt > @@ -18,6 +18,7 @@ pool management. > > Required properties: > - compatible : Must be "ti,keystone-navigator-qmss"; > + : Must be "ti,keystone-navigator-qmss-l" for NSS Lite I think, It will be more accurate to add K2G specific compat string like "ti,66ak2g-navss-qm": compatible = "ti,66ak2g-navss-qm", "ti,keystone-navigator-qmss"; because 66ak2g TRM doesn't mention "Navss light" and this Navss version is used only in 66ak2g Soc. As result, 66ak2g Navss QM is subset of of keystone 2 Navss QM which should be defined in DT by adding more specific compat string in addition to generic one. > - clocks : phandle to the reference clock for this device. > - queue-range : <start number> total range of queue numbers for the device. > - linkram0 : <address size> for internal link ram, where size is the total > @@ -39,6 +40,12 @@ Required properties: > - Descriptor memory setup region. > - Queue Management/Queue Proxy region for queue Push. > - Queue Management/Queue Proxy region for queue Pop. > + > +For NSS lite, following QMSS reg indexes are used in that order For 66AK2G NAVSS QM.. > + - Queue Peek region. > + - Queue configuration region. > + - Queue Management/Queue Proxy region for queue Push/Pop. > + > - queue-pools : child node classifying the queue ranges into pools. > Queue ranges are grouped into 3 type of pools: > - qpend : pool of qpend(interruptible) queues > diff --git a/drivers/soc/ti/knav_qmss.h b/drivers/soc/ti/knav_qmss.h > index 905b974..5fa1ce6 100644 > --- a/drivers/soc/ti/knav_qmss.h > +++ b/drivers/soc/ti/knav_qmss.h > @@ -292,6 +292,11 @@ struct knav_queue { > struct list_head list; > }; > > +enum qmss_version { > + QMSS, > + QMSS_LITE, QMSS_66AK2G > +}; > + > struct knav_device { > struct device *dev; > unsigned base_id; > @@ -305,6 +310,7 @@ struct knav_device { > struct list_head pools; > struct list_head pdsps; > struct list_head qmgrs; > + enum qmss_version version; > }; > [...] > } > > +/* Match table for of_platform binding */ > +static const struct of_device_id keystone_qmss_of_match[] = { > + { > + .compatible = "ti,keystone-navigator-qmss", .data = (void *)QMSS, > + }, > + { > + .compatible = "ti,keystone-navigator-qmss-l", > + .data = (void *)QMSS_LITE, > + }, > + {}, > +}; > +MODULE_DEVICE_TABLE(of, keystone_qmss_of_match); > + > static int knav_queue_probe(struct platform_device *pdev) > { > struct device_node *node = pdev->dev.of_node; > struct device_node *qmgrs, *queue_pools, *regions, *pdsps; > + const struct of_device_id *match; > struct device *dev = &pdev->dev; > u32 temp[2]; > int ret; > @@ -1700,6 +1749,10 @@ static int knav_queue_probe(struct platform_device *pdev) > return -ENOMEM; > } > > + match = of_match_device(of_match_ptr(keystone_qmss_of_match), dev); > + if (match && match->data) > + kdev->version = QMSS_LITE; if (match) kdev->version = match->data; else error? [...] -- regards, -grygorii -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html