[PATCH] drm/radeon: replace 1-element arrays with flexible-array members

José Pekkarinen jose.pekkarinen at foxhound.fi
Tue Oct 31 17:00:39 UTC 2023


On 2023-10-31 17:45, Alex Deucher wrote:
> On Sat, Oct 28, 2023 at 8:05 AM José Pekkarinen
> <jose.pekkarinen at foxhound.fi> wrote:
>> 
>> On 2023-10-27 20:55, Deucher, Alexander wrote:
>> > [Public]
>> >
>> >> -----Original Message-----
>> >> From: José Pekkarinen <jose.pekkarinen at foxhound.fi>
>> >> Sent: Friday, October 27, 2023 12:59 PM
>> >> To: Deucher, Alexander <Alexander.Deucher at amd.com>; Koenig, Christian
>> >> <Christian.Koenig at amd.com>; Pan, Xinhui <Xinhui.Pan at amd.com>;
>> >> skhan at linuxfoundation.org
>> >> Cc: José Pekkarinen <jose.pekkarinen at foxhound.fi>; airlied at gmail.com;
>> >> daniel at ffwll.ch; amd-gfx at lists.freedesktop.org; dri-
>> >> devel at lists.freedesktop.org; linux-kernel at vger.kernel.org;
>> >> linux-kernel-
>> >> mentees at lists.linuxfoundation.org
>> >> Subject: [PATCH] drm/radeon: replace 1-element arrays with
>> >> flexible-array
>> >> members
>> >>
>> >> Reported by coccinelle, the following patch will move the following 1
>> >> element
>> >> arrays to flexible arrays.
>> >>
>> >> drivers/gpu/drm/radeon/atombios.h:5523:32-48: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:5545:32-48: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:5461:34-44: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:4447:30-40: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:4236:30-41: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7044:24-37: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7054:24-37: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7095:28-45: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7553:8-17: WARNING use
>> >> flexible-array
>> >> member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7559:8-17: WARNING use
>> >> flexible-array
>> >> member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:3896:27-37: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:5443:16-25: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:5454:34-43: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:4603:21-32: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:6299:32-44: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:4628:32-46: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:6285:29-39: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:4296:30-36: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:4756:28-36: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:4064:22-35: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7327:9-24: WARNING use
>> >> flexible-array
>> >> member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7332:32-53: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:6030:8-17: WARNING use
>> >> flexible-array
>> >> member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7362:26-41: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7369:29-44: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7349:24-32: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >> drivers/gpu/drm/radeon/atombios.h:7355:27-35: WARNING use flexible-
>> >> array member instead
>> >> (https://www.kernel.org/doc/html/latest/process/deprecated.html#zero-
>> >> length-and-one-element-arrays)
>> >>
>> >> Signed-off-by: José Pekkarinen <jose.pekkarinen at foxhound.fi>
>> >
>> > Please verify that changing these to variable sized arrays does not
>> > break any calculations based on the old size in the driver.  More
>> > below.
>> >
>> >> ---
>> >>  drivers/gpu/drm/radeon/atombios.h | 54
>> >> +++++++++++++++----------------
>> >>  1 file changed, 27 insertions(+), 27 deletions(-)
>> >>
>> >> diff --git a/drivers/gpu/drm/radeon/atombios.h
>> >> b/drivers/gpu/drm/radeon/atombios.h
>> >> index 8a6621f1e82c..7fa1606be92c 100644
>> >> --- a/drivers/gpu/drm/radeon/atombios.h
>> >> +++ b/drivers/gpu/drm/radeon/atombios.h
>> >> @@ -3893,7 +3893,7 @@ typedef struct _ATOM_GPIO_PIN_ASSIGNMENT
>> >> typedef struct _ATOM_GPIO_PIN_LUT  {
>> >>    ATOM_COMMON_TABLE_HEADER  sHeader;
>> >> -  ATOM_GPIO_PIN_ASSIGNMENT   asGPIO_Pin[1];
>> >> +  ATOM_GPIO_PIN_ASSIGNMENT   asGPIO_Pin[];
>> >>  }ATOM_GPIO_PIN_LUT;
>> >>
>> >>
>> >> /******************************************************************
>> >> **********/
>> >> @@ -4061,7 +4061,7 @@ typedef struct
>> >> _ATOM_SRC_DST_TABLE_FOR_ONE_OBJECT         //usSrcDstTableOffset
>> >>    UCHAR               ucNumberOfSrc;
>> >>    USHORT              usSrcObjectID[1];
>> >>    UCHAR               ucNumberOfDst;
>> >> -  USHORT              usDstObjectID[1];
>> >> +  USHORT              usDstObjectID[];
>> >>  }ATOM_SRC_DST_TABLE_FOR_ONE_OBJECT;
>> >>
>> >>
>> >> @@ -4233,7 +4233,7 @@ typedef struct
>> >> _ATOM_CONNECTOR_DEVICE_TAG_RECORD
>> >>    ATOM_COMMON_RECORD_HEADER   sheader;
>> >>    UCHAR                       ucNumberOfDevice;
>> >>    UCHAR                       ucReserved;
>> >> -  ATOM_CONNECTOR_DEVICE_TAG   asDeviceTag[1];         //This Id is
>> >> same as
>> >> "ATOM_DEVICE_XXX_SUPPORT", 1 is only for allocation
>> >> +  ATOM_CONNECTOR_DEVICE_TAG   asDeviceTag[];          //This Id is
>> >> same as
>> >> "ATOM_DEVICE_XXX_SUPPORT", 1 is only for allocation
>> >>  }ATOM_CONNECTOR_DEVICE_TAG_RECORD;
>> >>
>> >>
>> >> @@ -4293,7 +4293,7 @@ typedef struct
>> >> _ATOM_OBJECT_GPIO_CNTL_RECORD
>> >>    ATOM_COMMON_RECORD_HEADER   sheader;
>> >>    UCHAR                       ucFlags;                // Future
>> >> expnadibility
>> >>    UCHAR                       ucNumberOfPins;         // Number of
>> >> GPIO pins used to
>> >> control the object
>> >> -  ATOM_GPIO_PIN_CONTROL_PAIR  asGpio[1];              // the real
>> >> gpio pin pair
>> >> determined by number of pins ucNumberOfPins
>> >> +  ATOM_GPIO_PIN_CONTROL_PAIR  asGpio[];               // the real
>> >> gpio pin pair
>> >> determined by number of pins ucNumberOfPins
>> >>  }ATOM_OBJECT_GPIO_CNTL_RECORD;
>> >>
>> >>  //Definitions for GPIO pin state
>> >> @@ -4444,7 +4444,7 @@ typedef struct
>> >> _ATOM_BRACKET_LAYOUT_RECORD
>> >>    UCHAR                       ucWidth;
>> >>    UCHAR                       ucConnNum;
>> >>    UCHAR                       ucReserved;
>> >> -  ATOM_CONNECTOR_LAYOUT_INFO  asConnInfo[1];
>> >> +  ATOM_CONNECTOR_LAYOUT_INFO  asConnInfo[];
>> >>  }ATOM_BRACKET_LAYOUT_RECORD;
>> >>
>> >>
>> >> /******************************************************************
>> >> **********/
>> >> @@ -4600,7 +4600,7 @@ typedef struct  _ATOM_I2C_VOLTAGE_OBJECT_V3
>> >>     UCHAR    ucVoltageControlAddress;
>> >>     UCHAR    ucVoltageControlOffset;
>> >>     ULONG    ulReserved;
>> >> -   VOLTAGE_LUT_ENTRY asVolI2cLut[1];        // end with 0xff
>> >> +   VOLTAGE_LUT_ENTRY asVolI2cLut[];         // end with 0xff
>> >>  }ATOM_I2C_VOLTAGE_OBJECT_V3;
>> >>
>> >>  // ATOM_I2C_VOLTAGE_OBJECT_V3.ucVoltageControlFlag
>> >> @@ -4625,7 +4625,7 @@ typedef struct
>> >> _ATOM_LEAKAGE_VOLTAGE_OBJECT_V3
>> >>     UCHAR    ucLeakageEntryNum;           // indicate the entry number
>> >> of
>> >> LeakageId/Voltage Lut table
>> >>     UCHAR    ucReserved[2];
>> >>     ULONG    ulMaxVoltageLevel;
>> >> -   LEAKAGE_VOLTAGE_LUT_ENTRY_V2 asLeakageIdLut[1];
>> >> +   LEAKAGE_VOLTAGE_LUT_ENTRY_V2 asLeakageIdLut[];
>> >>  }ATOM_LEAKAGE_VOLTAGE_OBJECT_V3;
>> >>
>> >>
>> >> @@ -4753,7 +4753,7 @@ typedef struct _ATOM_POWER_SOURCE_INFO  {
>> >>               ATOM_COMMON_TABLE_HEADER                asHeader;
>> >>               UCHAR
>> >>                                       asPwrbehave[16];
>> >> -             ATOM_POWER_SOURCE_OBJECT                asPwrObj[1];
>> >> +             ATOM_POWER_SOURCE_OBJECT                asPwrObj[];
>> >>  }ATOM_POWER_SOURCE_INFO;
>> >>
>> >>
>> >> @@ -5440,7 +5440,7 @@ typedef struct _ATOM_FUSION_SYSTEM_INFO_V2
>> >> typedef struct _ATOM_I2C_DATA_RECORD  {
>> >>    UCHAR         ucNunberOfBytes;
>> >>         //Indicates how many
>> >> bytes SW needs to write to the external ASIC for one block, besides to
>> >> "Start"
>> >> and "Stop"
>> >> -  UCHAR         ucI2CData[1];
>> >>         //I2C data in bytes,
>> >> should be less than 16 bytes usually
>> >> +  UCHAR         ucI2CData[];
>> >>         //I2C data in bytes, should
>> >> be less than 16 bytes usually
>> >>  }ATOM_I2C_DATA_RECORD;
>> >>
>> >>
>> >> @@ -5451,14 +5451,14 @@ typedef struct
>> >> _ATOM_I2C_DEVICE_SETUP_INFO
>> >>    UCHAR                                      ucSSChipID;
>> >> //SS chip being used
>> >>    UCHAR                                      ucSSChipSlaveAddr;
>> >> //Slave Address to
>> >> set up this SS chip
>> >>    UCHAR                           ucNumOfI2CDataRecords;  //number of
>> >> data block
>> >> -  ATOM_I2C_DATA_RECORD            asI2CData[1];
>> >> +  ATOM_I2C_DATA_RECORD            asI2CData[];
>> >>  }ATOM_I2C_DEVICE_SETUP_INFO;
>> >>
>> >>
>> >> //=================================================================
>> >> =========================
>> >>  typedef struct  _ATOM_ASIC_MVDD_INFO
>> >>  {
>> >>    ATOM_COMMON_TABLE_HEADER         sHeader;
>> >> -  ATOM_I2C_DEVICE_SETUP_INFO      asI2CSetup[1];
>> >> +  ATOM_I2C_DEVICE_SETUP_INFO      asI2CSetup[];
>> >>  }ATOM_ASIC_MVDD_INFO;
>> >>
>> >>
>> >> //=================================================================
>> >> =========================
>> >> @@ -5520,7 +5520,7 @@ typedef struct _ATOM_ASIC_INTERNAL_SS_INFO
>> >> typedef struct _ATOM_ASIC_INTERNAL_SS_INFO_V2  {
>> >>    ATOM_COMMON_TABLE_HEADER         sHeader;
>> >> -  ATOM_ASIC_SS_ASSIGNMENT_V2           asSpreadSpectrum[1];
>> >> //this is point only.
>> >> +  ATOM_ASIC_SS_ASSIGNMENT_V2           asSpreadSpectrum[];
>> >> //this is point only.
>> >>  }ATOM_ASIC_INTERNAL_SS_INFO_V2;
>> >>
>> >>  typedef struct _ATOM_ASIC_SS_ASSIGNMENT_V3 @@ -5542,7 +5542,7 @@
>> >> typedef struct _ATOM_ASIC_SS_ASSIGNMENT_V3  typedef struct
>> >> _ATOM_ASIC_INTERNAL_SS_INFO_V3  {
>> >>    ATOM_COMMON_TABLE_HEADER         sHeader;
>> >> -  ATOM_ASIC_SS_ASSIGNMENT_V3           asSpreadSpectrum[1];
>> >> //this is pointer only.
>> >> +  ATOM_ASIC_SS_ASSIGNMENT_V3           asSpreadSpectrum[];
>> >> //this is pointer only.
>> >>  }ATOM_ASIC_INTERNAL_SS_INFO_V3;
>> >>
>> >>
>> >> @@ -6027,7 +6027,7 @@ typedef struct _ENABLE_SCALER_PARAMETERS
>> >>    UCHAR ucScaler;            // ATOM_SCALER1, ATOM_SCALER2
>> >>    UCHAR ucEnable;            // ATOM_SCALER_DISABLE or
>> >> ATOM_SCALER_CENTER or ATOM_SCALER_EXPANSION
>> >>    UCHAR ucTVStandard;        //
>> >> -  UCHAR ucPadding[1];
>> >> +  UCHAR ucPadding[];
>> >
>> > This may actually be a 1 element array.  It’s just padding at the end
>> > of the table.
>> >
>> >>  }ENABLE_SCALER_PARAMETERS;
>> >>  #define ENABLE_SCALER_PS_ALLOCATION ENABLE_SCALER_PARAMETERS
>> >>
>> >> @@ -6282,7 +6282,7 @@ typedef union
>> >> _ATOM_MEMORY_SETTING_ID_CONFIG_ACCESS
>> >>
>> >>  typedef struct _ATOM_MEMORY_SETTING_DATA_BLOCK{
>> >>       ATOM_MEMORY_SETTING_ID_CONFIG_ACCESS
>> >>       ulMemoryID;
>> >> -     ULONG
>> >>
>> >> aulMemData[1];
>> >> +     ULONG
>> >>
>> >> aulMemData[];
>> >>  }ATOM_MEMORY_SETTING_DATA_BLOCK;
>> >>
>> >>
>> >> @@ -6296,7 +6296,7 @@ typedef struct _ATOM_INIT_REG_BLOCK{
>> >>       USHORT
>> >>                                               usRegIndexTblSize;
>> >>
>> >>                       //size of asRegIndexBuf
>> >>       USHORT
>> >>                                               usRegDataBlkSize;
>> >>
>> >>                               //size of
>> >> ATOM_MEMORY_SETTING_DATA_BLOCK
>> >>       ATOM_INIT_REG_INDEX_FORMAT
>> >>       asRegIndexBuf[1];
>> >> -     ATOM_MEMORY_SETTING_DATA_BLOCK  asRegDataBuf[1];
>> >> +     ATOM_MEMORY_SETTING_DATA_BLOCK  asRegDataBuf[];
>> >>  }ATOM_INIT_REG_BLOCK;
>> >>
>> >
>> > This one needs special handling as you have multiple variable sized
>> > arrays.
>> 
>>      I'm happy to add any special handling in v2, though
>> I may need to understand what that special handling would
>> be. Would you mind to elaborate? Otherwise I can just leave
>> the sensitive cases and the paddings untouched and resend
>> the patch with the rest of cases converted.
> 
> 
> I'm not sure how we want to handle back to back variable sized arrays.
> I'd say just skip these cases for now.

     Very good, I'll be sending v2 soon. thanks for the comments!

     José.


More information about the dri-devel mailing list