diff mbox

drivers: stm: correct the index in master array release

Message ID 1453954889-6290-1-git-send-email-zhang.chunyan@linaro.org
State New
Headers show

Commit Message

Chunyan Zhang Jan. 28, 2016, 4:21 a.m. UTC
It would be broken if stm_data->sw_start isn't zero, because that
stp_master_free() get the 'master' with __stm_master()/stm_master(),
in which the masterID is the second input parameter minus
stm_data->sw_start. So freeing STM masters has to start from
stm_data->sw_start.

Signed-off-by: Chunyan Zhang <zhang.chunyan@linaro.org>

---
 drivers/hwtracing/stm/core.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

-- 
1.9.1

Comments

Chunyan Zhang Feb. 14, 2016, 6:25 a.m. UTC | #1
On Tue, Feb 9, 2016 at 6:12 PM, Alexander Shishkin
<alexander.shishkin@linux.intel.com> wrote:
> Chunyan Zhang <zhang.chunyan@linaro.org> writes:

>

>> It would be broken if stm_data->sw_start isn't zero, because that

>> stp_master_free() get the 'master' with __stm_master()/stm_master(),

>> in which the masterID is the second input parameter minus

>> stm_data->sw_start. So freeing STM masters has to start from

>> stm_data->sw_start.

>

> No, it won't. stm_master_free() handles nonexistent masters correctly.

> It does make sense to shrink the loop in stm_unregister_device() to

> avoid going through the [0..sw_start) range, since stm_master() returns

> NULL for those, but not for the reasons given in this patch description.


Let's assume sw_start = 64, sw_end = 79, sw_nmasters should be 16, if
the loop goes through [0..16), the existed masters will not be freed.
That's what I wanted to address in this patch. I meant the number of
loop in stm_unregister_device() is correct, but the start index isn't.
Sorry for not describing clear enough in the patch logs.

Thanks,
Chunyan

>

> Regards,

> --

> Alex
diff mbox

Patch

diff --git a/drivers/hwtracing/stm/core.c b/drivers/hwtracing/stm/core.c
index da53b5d..80e7b5e 100644
--- a/drivers/hwtracing/stm/core.c
+++ b/drivers/hwtracing/stm/core.c
@@ -718,7 +718,7 @@  void stm_unregister_device(struct stm_data *stm_data)
 		stp_policy_unbind(stm->policy);
 	mutex_unlock(&stm->policy_mutex);
 
-	for (i = 0; i < stm->sw_nmasters; i++)
+	for (i = stm->data->sw_start; i <= stm->data->sw_end; i++)
 		stp_master_free(stm, i);
 
 	device_unregister(&stm->dev);