[PATCH] amdgpu/drm: Refine the way to check atom bios

Ken Xue kxue at amd.com
Tue Dec 20 09:54:23 UTC 2016


Th 12/20/2016 12:09, Alex Deucher wrote:
> On Tue, Dec 20, 2016 at 2:20 AM, Xue, Ken <Ken.Xue at amd.com> wrote:
> > There are several ways to check out a ATOMBIOS. In previous codes, try
> > a new way to fetch out vbios/rom, until current vbios/rom is started with
> > 0x55aa, then check if this vbios is ATOMBIOS. Now, try a new way to fetch
> > out vbios until all flags of ATOMBIOS are verified.
> >
> > Signed-off-by: Ken Xue <Ken.Xue at amd.com>
> > ---
> >  drivers/gpu/drm/amd/amdgpu/amdgpu.h        |   2 +-
> >  drivers/gpu/drm/amd/amdgpu/amdgpu_bios.c   | 152 ++++++++++++++++-------------
> >  drivers/gpu/drm/amd/amdgpu/amdgpu_device.c |  10 +-
> >  3 files changed, 89 insertions(+), 75 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
> > index b7f521a..dd8acb9 100644
> > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h
> > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
> > @@ -305,7 +305,7 @@ struct amdgpu_ih_funcs {
> >  /*
> >   * BIOS.
> >   */
> > -bool amdgpu_get_bios(struct amdgpu_device *adev);
> > +bool amdgpu_get_atom_bios(struct amdgpu_device *adev);
> 
> No need to change the name of this function in my opinion, but I'm ok
> either way.
> 

Ok. I will revert the name of the function.

> >  bool amdgpu_read_bios(struct amdgpu_device *adev);
> >
> >  /*
> > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_bios.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_bios.c
> > index 4f973a9..86e7b43 100644
> > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_bios.c
> > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_bios.c
> > @@ -42,6 +42,44 @@
> >  #define AMD_IS_VALID_VBIOS(p) ((p)[0] == 0x55 && (p)[1] == 0xAA)
> >  #define AMD_VBIOS_LENGTH(p) ((p)[2] << 9)
> >
> > +/* Check if current bios is an ATOM BIOS.
> > + * Return true if it is ATOM BIOS. Otherwise, return false.
> > + */
> > +static bool check_atom_bios(uint8_t __iomem *bios, size_t size)
> > +{
> > +       uint16_t tmp, bios_header_start;
> > +
> > +       if (!bios || size < 0x49) {
> > +               DRM_INFO("vbios mem is null or mem size is wrong\n");
> > +               return false;
> > +       }
> > +
> > +       if (!AMD_IS_VALID_VBIOS(bios)) {
> > +               DRM_INFO("BIOS signature incorrect %x %x\n", bios[0], bios[1]);
> > +               return false;
> > +       }
> > +
> > +       tmp = bios[0x18] | (bios[0x19] << 8);
> > +       if (bios[tmp + 0x14] != 0x0) {
> > +               DRM_INFO("Not an x86 BIOS ROM\n");
> > +               return false;
> > +       }
> > +
> > +       bios_header_start = bios[0x48] | (bios[0x49] << 8);
> > +       if (!bios_header_start) {
> > +               DRM_INFO("Can't locate bios header\n");
> > +               return false;
> > +       }
> > +       tmp = bios_header_start + 4;
> > +       if (!memcmp(bios + tmp, "ATOM", 4) ||
> > +           !memcmp(bios + tmp, "MOTA", 4) ||
> > +           (size < tmp))
> > +               return true;
> > +
> > +       return false;
> > +}
> > +
> > +
> >  /* If you boot an IGP board with a discrete card as the primary,
> >   * the IGP rom is not accessible via the rom bar as the IGP rom is
> >   * part of the system bios.  On boot, the system bios puts a
> > @@ -65,7 +103,7 @@ static bool igp_read_bios_from_vram(struct amdgpu_device *adev)
> >                 return false;
> >         }
> >
> > -       if (size == 0 || !AMD_IS_VALID_VBIOS(bios)) {
> > +       if (!check_atom_bios(bios, size)) {
> >                 iounmap(bios);
> >                 return false;
> >         }
> > @@ -82,7 +120,7 @@ static bool igp_read_bios_from_vram(struct amdgpu_device *adev)
> >
> >  bool amdgpu_read_bios(struct amdgpu_device *adev)
> >  {
> > -       uint8_t __iomem *bios, val[2];
> > +       uint8_t __iomem *bios;
> >         size_t size;
> >
> >         adev->bios = NULL;
> > @@ -92,10 +130,7 @@ bool amdgpu_read_bios(struct amdgpu_device *adev)
> >                 return false;
> >         }
> >
> > -       val[0] = readb(&bios[0]);
> > -       val[1] = readb(&bios[1]);
> 
> We need to use io accessors on some platforms rather than accessing
> memory directly for pcie resources.  This should be preseved.
> 
> Alex
> 

Sure, Understand it. And I can see that some part of the original file also
does not use "readb" to access iomem, I will send a new patch for keep same
coding style for the file amdgpu_bios.c.

Regards,
Ken


More information about the amd-gfx mailing list