/* * Copyright (C) 2014 Marvell Technology Group Ltd. * * Marvell Berlin reset driver * * Antoine Tenart * Sebastian Hesselbarth * * This file is licensed under the terms of the GNU General Public * License version 2. This program is licensed "as is" without any * warranty of any kind, whether express or implied. */ #include #include #include #include #include #include #include #include #include #include #include #define BERLIN_MAX_RESETS 32 #define to_berlin_reset_priv(p) \ container_of((p), struct berlin_reset_priv, rcdev) struct berlin_reset_priv { struct regmap *regmap; struct reset_controller_dev rcdev; }; static int berlin_reset_reset(struct reset_controller_dev *rcdev, unsigned long id) { struct berlin_reset_priv *priv = to_berlin_reset_priv(rcdev); int offset = id >> 8; int mask = BIT(id & 0x1f); regmap_write(priv->regmap, offset, mask); /* let the reset be effective */ udelay(10); return 0; } static const struct reset_control_ops berlin_reset_ops = { .reset = berlin_reset_reset, }; static int berlin_reset_xlate(struct reset_controller_dev *rcdev, const struct of_phandle_args *reset_spec) { unsigned offset, bit; offset = reset_spec->args[0]; bit = reset_spec->args[1]; if (bit >= BERLIN_MAX_RESETS) return -EINVAL; return (offset << 8) | bit; } static int berlin2_reset_probe(struct platform_device *pdev) { struct device_node *parent_np = of_get_parent(pdev->dev.of_node); struct berlin_reset_priv *priv; priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL); if (!priv) return -ENOMEM; priv->regmap = syscon_node_to_regmap(parent_np); of_node_put(parent_np); if (IS_ERR(priv->regmap)) return PTR_ERR(priv->regmap); priv->rcdev.owner = THIS_MODULE; priv->rcdev.ops = &berlin_reset_ops; priv->rcdev.of_node = pdev->dev.of_node; priv->rcdev.of_reset_n_cells = 2; priv->rcdev.of_xlate = berlin_reset_xlate; return reset_controller_register(&priv->rcdev); } static const struct of_device_id berlin_reset_dt_match[] = { { .compatible = "marvell,berlin2-reset" }, { }, }; static struct platform_driver berlin_reset_driver = { .probe = berlin2_reset_probe, .driver = { .name = "berlin2-reset", .of_match_table = berlin_reset_dt_match, }, }; builtin_platform_driver(berlin_reset_driver); ux.org.uk/linux-net-next.git/commit/?id=b7683155517c09c7e0f9d791eaab6dab3b4b2477'>root/drivers/net
diff options
context:
space:
mode:
authorEdward Cree <ecree@solarflare.com>2020-02-17 13:43:10 +0000
committerDavid S. Miller <davem@davemloft.net>2020-02-17 14:35:23 -0800
commitb7683155517c09c7e0f9d791eaab6dab3b4b2477 (patch)
treecea3ca29b8db6619ce2b9f90695c919f0f3d1fd1 /drivers/net
parentbd706ff8ea2b6e2d3f21f0863b2fc42f860f8ba2 (diff)
sfc: only schedule asynchronous filter work if needed
Prevent excessive CPU time spent running a workitem with nothing to do. We avoid any races by keeping the same check in efx_filter_rfs_expire(). Suggested-by: Martin Habets <mhabets@solarflare.com> Signed-off-by: Edward Cree <ecree@solarflare.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')