[PATCH 6/8] net: ethernet driver: Fujitsu OGMA

Andy Green andy.green at linaro.org
Mon Jul 14 03:36:11 PDT 2014


On 14 July 2014 17:06, Tobias Klauser <tklauser at distanz.ch> wrote:
> On 2014-07-13 at 08:31:47 +0200, Mollie Wu <mollie.wu at linaro.org> wrote:
>> This driver adds support for "ogma", a Fujitsu Semiconductor Ltd IP Gigabit
>> Ethernet + PHY IP used in a variety of their ARM-based ASICs.
>>
>> This is being sent as part of a series including the arch support that uses it,
>> Fujitsu mb86s7x.
>>
>> This driver was originally written by guys inside Fujitsu as an abstracted
>> "you can build this for Windows as well" type code, I've removed all that,
>> modernized various things, added runtime_pm, and ported it to work with
>> Device Tree, using only the bindings already mentioned in
>>
>> ./Documentation/devicetree/bindings/net/ethernet.txt
>>
>> Bindings documentation is added by this patch.
>>
>> Signed-off-by: Andy Green <andy.green at linaro.org>
>> Signed-off-by: Tetsuya Takinishi <t.takinishi at jp.fujitsu.com>
>> Signed-off-by: Mollie Wu <mollie.wu at linaro.org>
>> ---
>>  .../devicetree/bindings/net/fujitsu-ogma.txt       |  43 ++
>>  drivers/net/ethernet/fujitsu/Kconfig               |  12 +
>>  drivers/net/ethernet/fujitsu/Makefile              |   1 +
>>  drivers/net/ethernet/fujitsu/ogma/Makefile         |   6 +
>>  drivers/net/ethernet/fujitsu/ogma/ogma.h           | 380 +++++++++++++
>>  .../ethernet/fujitsu/ogma/ogma_desc_ring_access.c  | 627 +++++++++++++++++++++
>>  drivers/net/ethernet/fujitsu/ogma/ogma_ethtool.c   |  95 ++++
>>  .../net/ethernet/fujitsu/ogma/ogma_gmac_access.c   | 295 ++++++++++
>>  drivers/net/ethernet/fujitsu/ogma/ogma_netdev.c    | 592 +++++++++++++++++++
>>  drivers/net/ethernet/fujitsu/ogma/ogma_platform.c  | 333 +++++++++++
>>  10 files changed, 2384 insertions(+)
>>  create mode 100644 Documentation/devicetree/bindings/net/fujitsu-ogma.txt
>>  create mode 100644 drivers/net/ethernet/fujitsu/ogma/Makefile
>>  create mode 100644 drivers/net/ethernet/fujitsu/ogma/ogma.h
>>  create mode 100644 drivers/net/ethernet/fujitsu/ogma/ogma_desc_ring_access.c
>>  create mode 100644 drivers/net/ethernet/fujitsu/ogma/ogma_ethtool.c
>>  create mode 100644 drivers/net/ethernet/fujitsu/ogma/ogma_gmac_access.c
>>  create mode 100644 drivers/net/ethernet/fujitsu/ogma/ogma_netdev.c
>>  create mode 100644 drivers/net/ethernet/fujitsu/ogma/ogma_platform.c
>
> [...]
>
>> diff --git a/drivers/net/ethernet/fujitsu/ogma/ogma_platform.c b/drivers/net/ethernet/fujitsu/ogma/ogma_platform.c
>> new file mode 100644
>> index 0000000..09071da
>> --- /dev/null
>> +++ b/drivers/net/ethernet/fujitsu/ogma/ogma_platform.c
>
> [...]
>
>> +#ifdef CONFIG_PM
>> +static const struct dev_pm_ops ogma_pm_ops = {
>> +     SET_SYSTEM_SLEEP_PM_OPS(ogma_pm_suspend, ogma_pm_resume)
>> +     SET_RUNTIME_PM_OPS(ogma_runtime_suspend, ogma_runtime_resume, NULL)
>> +};
>> +#endif
>
> #ifdef CONFIG_PM can be omitted here since
> SET_{SYSTEM_SLEEP,RUNTIME}_PM_OPS will just evaluate empty if CONFIG_PM
> is not defined.
>
>> +
>> +static const struct of_device_id ogma_dt_ids[] = {
>> +     {.compatible = "fujitsu,ogma"},
>> +     { /* sentinel */ }
>> +};
>> +
>> +MODULE_DEVICE_TABLE(of, ogma_dt_ids);
>> +
>> +static struct platform_driver ogma_driver = {
>> +     .probe = ogma_probe,
>> +     .remove = ogma_remove,
>> +     .driver = {
>> +             .name = "ogma",
>> +             .of_match_table = ogma_dt_ids,
>> +#ifdef CONFIG_PM
>> +             .pm = &ogma_pm_ops,
>> +#endif
>
> With the above #ifdef CONFIG_PM removed, ogma_pm_ops will be all NULL if
> CONFIG_PM is not set. Thus, the #ifdef can be removed as well.

OK will fix, thanks.

-Andy

>> +             },
>> +};
>> +
>> +module_platform_driver(ogma_driver);
>> +
>> +MODULE_AUTHOR("Fujitsu Semiconductor Ltd");
>> +MODULE_DESCRIPTION("OGMA Ethernet driver");
>> +MODULE_LICENSE("GPL");
>> +
>> +MODULE_ALIAS("platform:ogma");
>> --
>> 1.8.1.2



More information about the linux-arm-kernel mailing list