Commit bce00f41 authored by Alexander Shishkin's avatar Alexander Shishkin Committed by Greg Kroah-Hartman

intel_th: gth: Fix an off-by-one in output unassigning

commit 91d3f8a6 upstream.

Commit 9ed3f222 ("intel_th: Don't reference unassigned outputs")
fixes a NULL dereference for all masters except the last one ("256+"),
which keeps the stale pointer after the output driver had been unassigned.

Fix the off-by-one.
Signed-off-by: default avatarAlexander Shishkin <alexander.shishkin@linux.intel.com>
Fixes: 9ed3f222 ("intel_th: Don't reference unassigned outputs")
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 9c8c39ba
...@@ -616,7 +616,7 @@ static void intel_th_gth_unassign(struct intel_th_device *thdev, ...@@ -616,7 +616,7 @@ static void intel_th_gth_unassign(struct intel_th_device *thdev,
othdev->output.port = -1; othdev->output.port = -1;
othdev->output.active = false; othdev->output.active = false;
gth->output[port].output = NULL; gth->output[port].output = NULL;
for (master = 0; master < TH_CONFIGURABLE_MASTERS; master++) for (master = 0; master <= TH_CONFIGURABLE_MASTERS; master++)
if (gth->master[master] == port) if (gth->master[master] == port)
gth->master[master] = -1; gth->master[master] = -1;
spin_unlock(&gth->gth_lock); spin_unlock(&gth->gth_lock);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment