lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <865037d1-c89f-4142-a66f-3283c17bf533@kernel.org>
Date: Fri, 31 Oct 2025 14:19:17 +0100
From: Krzysztof Kozlowski <krzk@...nel.org>
To: webgeek1234@...il.com, Thierry Reding <thierry.reding@...il.com>,
 Jonathan Hunter <jonathanh@...dia.com>
Cc: linux-kernel@...r.kernel.org, linux-tegra@...r.kernel.org
Subject: Re: [PATCH v6] memory: tegra210: Support interconnect framework

On 27/10/2025 18:48, Aaron Kling via B4 Relay wrote:
> +
> +	err = dev_pm_opp_of_add_table(emc->dev);
> +	if (err) {
> +		if (err == -ENODEV)
> +			dev_err_probe(emc->dev, err,
> +				      "OPP table not found, please update your device tree\n");
> +		else
> +			dev_err_probe(emc->dev, err, "failed to add OPP table\n");
> +
> +		goto put_hw_table;
> +	}
> +
> +	max_opps = dev_pm_opp_get_opp_count(emc->dev);
> +	if (max_opps <= 0) {
> +		dev_err_probe(emc->dev, err, "Failed to add OPPs\n");
> +		goto remove_table;
> +	}
> +
> +	if (emc->num_timings != max_opps) {
> +		dev_err_probe(emc->dev, err, "OPP table does not match emc table\n");
> +		goto remove_table;
> +	}
> +
> +	for (i = 0; i < emc->num_timings; i++) {
> +		rate = emc->timings[i].rate * 1000;
> +		opp = dev_pm_opp_find_freq_exact(emc->dev, rate, true);
> +		if (IS_ERR(opp)) {
> +			dev_err_probe(emc->dev, err, "Rate %lu not found in OPP table\n", rate);
> +			goto remove_table;
> +		}
> +
> +		dev_pm_opp_put(opp);
> +	}
> +
> +	dev_info_once(emc->dev, "OPP HW ver. 0x%x, current clock rate %lu MHz\n",
> +		      hw_version, clk_get_rate(emc->clk) / 1000000);
> +
> +	return 0;
> +
> +remove_table:
> +	dev_pm_opp_of_remove_table(emc->dev);
> +put_hw_table:
> +	dev_pm_opp_put_supported_hw(opp_token);
> +
> +	return err;
> +}
> +
>  static void tegra210_emc_detect(struct tegra210_emc *emc)
>  {
>  	u32 value;
> @@ -1966,6 +2222,14 @@ static int tegra210_emc_probe(struct platform_device *pdev)
>  
>  	tegra210_emc_debugfs_init(emc);
>  
> +	err = tegra210_emc_opp_table_init(emc);
> +	if (!err) {
> +		tegra210_emc_rate_requests_init(emc);
> +		tegra210_emc_interconnect_init(emc);

This looks like new ABI or did I miss something and it is already
documented? If so please always mention in the changelog that bindings
are already merged to master tree.

Same question for earlier PM OPP.


> +	} else if (err != -ENODEV) {
> +		return err;
> +	}
> +
>  	cd = devm_thermal_of_cooling_device_register(emc->dev, np, "emc", emc,
>  				

Best regards,
Krzysztof

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ