[media] cec: an inner loop clobbered the outer loop variable

An inner for-loop reused the outer loop variable. This was
only noticeable with CEC adapters supporting more than one
logical address.

Signed-off-by: Hans Verkuil <hansverk@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
This commit is contained in:
Hans Verkuil 2016-11-04 10:52:10 -02:00 committed by Mauro Carvalho Chehab
parent 3145c754ac
commit a161bef042
1 changed files with 5 additions and 4 deletions

View File

@ -1416,6 +1416,7 @@ int __cec_s_log_addrs(struct cec_adapter *adap,
const u8 feature_sz = ARRAY_SIZE(log_addrs->features[0]); const u8 feature_sz = ARRAY_SIZE(log_addrs->features[0]);
u8 *features = log_addrs->features[i]; u8 *features = log_addrs->features[i];
bool op_is_dev_features = false; bool op_is_dev_features = false;
unsigned j;
log_addrs->log_addr[i] = CEC_LOG_ADDR_INVALID; log_addrs->log_addr[i] = CEC_LOG_ADDR_INVALID;
if (type_mask & (1 << log_addrs->log_addr_type[i])) { if (type_mask & (1 << log_addrs->log_addr_type[i])) {
@ -1442,19 +1443,19 @@ int __cec_s_log_addrs(struct cec_adapter *adap,
dprintk(1, "unknown logical address type\n"); dprintk(1, "unknown logical address type\n");
return -EINVAL; return -EINVAL;
} }
for (i = 0; i < feature_sz; i++) { for (j = 0; j < feature_sz; j++) {
if ((features[i] & 0x80) == 0) { if ((features[j] & 0x80) == 0) {
if (op_is_dev_features) if (op_is_dev_features)
break; break;
op_is_dev_features = true; op_is_dev_features = true;
} }
} }
if (!op_is_dev_features || i == feature_sz) { if (!op_is_dev_features || j == feature_sz) {
dprintk(1, "malformed features\n"); dprintk(1, "malformed features\n");
return -EINVAL; return -EINVAL;
} }
/* Zero unused part of the feature array */ /* Zero unused part of the feature array */
memset(features + i + 1, 0, feature_sz - i - 1); memset(features + j + 1, 0, feature_sz - j - 1);
} }
if (log_addrs->cec_version >= CEC_OP_CEC_VERSION_2_0) { if (log_addrs->cec_version >= CEC_OP_CEC_VERSION_2_0) {