Commit d3815ea9 authored by Thierry Escande's avatar Thierry Escande Committed by Samuel Ortiz

NFC: port100: Fix possible buffer overflow

The arrays for protocols and rf techs must define a number of entries
corresponding to their maximum possible index values.
Reported-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarThierry Escande <thierry.escande@linux.intel.com>
Signed-off-by: default avatarSamuel Ortiz <sameo@linux.intel.com>
parent f1dd56fd
...@@ -139,6 +139,8 @@ static const struct port100_in_rf_setting in_rf_settings[] = { ...@@ -139,6 +139,8 @@ static const struct port100_in_rf_setting in_rf_settings[] = {
.in_recv_set_number = 15, .in_recv_set_number = 15,
.in_recv_comm_type = PORT100_COMM_TYPE_IN_106A, .in_recv_comm_type = PORT100_COMM_TYPE_IN_106A,
}, },
/* Ensures the array has NFC_DIGITAL_RF_TECH_LAST elements */
[NFC_DIGITAL_RF_TECH_LAST] = { 0 },
}; };
/** /**
...@@ -174,6 +176,9 @@ static const struct port100_tg_rf_setting tg_rf_settings[] = { ...@@ -174,6 +176,9 @@ static const struct port100_tg_rf_setting tg_rf_settings[] = {
.tg_set_number = 8, .tg_set_number = 8,
.tg_comm_type = PORT100_COMM_TYPE_TG_424F, .tg_comm_type = PORT100_COMM_TYPE_TG_424F,
}, },
/* Ensures the array has NFC_DIGITAL_RF_TECH_LAST elements */
[NFC_DIGITAL_RF_TECH_LAST] = { 0 },
}; };
#define PORT100_IN_PROT_INITIAL_GUARD_TIME 0x00 #define PORT100_IN_PROT_INITIAL_GUARD_TIME 0x00
...@@ -330,6 +335,10 @@ in_protocols[][PORT100_IN_MAX_NUM_PROTOCOLS + 1] = { ...@@ -330,6 +335,10 @@ in_protocols[][PORT100_IN_MAX_NUM_PROTOCOLS + 1] = {
[NFC_DIGITAL_FRAMING_NFC_DEP_ACTIVATED] = { [NFC_DIGITAL_FRAMING_NFC_DEP_ACTIVATED] = {
{ PORT100_IN_PROT_END, 0 }, { PORT100_IN_PROT_END, 0 },
}, },
/* Ensures the array has NFC_DIGITAL_FRAMING_LAST elements */
[NFC_DIGITAL_FRAMING_LAST] = {
{ PORT100_IN_PROT_END, 0 },
},
}; };
static struct port100_protocol static struct port100_protocol
...@@ -371,6 +380,10 @@ tg_protocols[][PORT100_TG_MAX_NUM_PROTOCOLS + 1] = { ...@@ -371,6 +380,10 @@ tg_protocols[][PORT100_TG_MAX_NUM_PROTOCOLS + 1] = {
{ PORT100_TG_PROT_RF_OFF, 1 }, { PORT100_TG_PROT_RF_OFF, 1 },
{ PORT100_TG_PROT_END, 0 }, { PORT100_TG_PROT_END, 0 },
}, },
/* Ensures the array has NFC_DIGITAL_FRAMING_LAST elements */
[NFC_DIGITAL_FRAMING_LAST] = {
{ PORT100_TG_PROT_END, 0 },
},
}; };
struct port100 { struct port100 {
......
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