[PATCH v12 2/2] i2c: aspeed: support ast2600 i2c new register mode driver
Krzysztof Kozlowski
krzysztof.kozlowski at linaro.org
Fri Jul 14 18:03:03 AEST 2023
On 14/07/2023 09:45, Ryan Chen wrote:
> Add i2c new register mode driver to support AST2600 i2c
> new register mode. AST2600 i2c controller have legacy and
> new register mode. The new register mode have global register
> support 4 base clock for scl clock selection, and new clock
> divider mode. The i2c new register mode have separate register
> set to control i2c master and slave.
>
> Signed-off-by: Ryan Chen <ryan_chen at aspeedtech.com>
> ---
...
> + ret = devm_i2c_add_adapter(dev, &i2c_bus->adap);
> + if (ret)
> + return ret;
> +
> + return 0;
> +}
> +
> +static int ast2600_i2c_remove(struct platform_device *pdev)
> +{
> + struct ast2600_i2c_bus *i2c_bus = platform_get_drvdata(pdev);
> +
> + /* Disable everything. */
> + writel(0, i2c_bus->reg_base + AST2600_I2CC_FUN_CTRL);
> + writel(0, i2c_bus->reg_base + AST2600_I2CM_IER);
> +
> + i2c_del_adapter(&i2c_bus->adap);
I have doubts that you tested this. I think you have here double
free/del of the adapter.
> + devm_free_irq(&pdev->dev, i2c_bus->irq, i2c_bus);
> +
Best regards,
Krzysztof
More information about the Linux-aspeed
mailing list