2010-02-16 21:39:59 +00:00
|
|
|
/*
|
|
|
|
* GRUB -- GRand Unified Bootloader
|
|
|
|
* Copyright (C) 2010 Free Software Foundation, Inc.
|
|
|
|
*
|
|
|
|
* GRUB is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* GRUB is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with GRUB. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <grub/types.h>
|
|
|
|
#include <grub/misc.h>
|
|
|
|
#include <grub/mm.h>
|
|
|
|
#include <grub/err.h>
|
|
|
|
#include <grub/dl.h>
|
|
|
|
#include <grub/command.h>
|
|
|
|
#include <grub/cs5536.h>
|
2011-11-11 23:34:14 +00:00
|
|
|
#include <grub/i18n.h>
|
2010-02-16 21:39:59 +00:00
|
|
|
|
2011-04-11 21:01:51 +00:00
|
|
|
GRUB_MOD_LICENSE ("GPLv3+");
|
|
|
|
|
2010-02-16 21:39:59 +00:00
|
|
|
static grub_err_t
|
|
|
|
grub_cmd_lsspd (grub_command_t cmd __attribute__ ((unused)),
|
|
|
|
int argc __attribute__ ((unused)),
|
|
|
|
char **args __attribute__ ((unused)))
|
|
|
|
{
|
|
|
|
grub_pci_device_t dev;
|
|
|
|
grub_port_t smbbase;
|
|
|
|
int i;
|
|
|
|
grub_err_t err;
|
|
|
|
|
|
|
|
if (!grub_cs5536_find (&dev))
|
|
|
|
{
|
2011-11-11 23:34:14 +00:00
|
|
|
grub_puts_ (N_("No CS5536 found"));
|
2010-02-16 21:39:59 +00:00
|
|
|
return GRUB_ERR_NONE;
|
|
|
|
}
|
2011-11-11 23:34:14 +00:00
|
|
|
grub_printf_ (N_("CS5536 at %d:%d.%d\n"), grub_pci_get_bus (dev),
|
|
|
|
grub_pci_get_device (dev), grub_pci_get_function (dev));
|
2010-02-16 21:39:59 +00:00
|
|
|
|
|
|
|
err = grub_cs5536_init_smbus (dev, 0x7fff, &smbbase);
|
|
|
|
if (err)
|
|
|
|
return err;
|
|
|
|
|
2012-02-08 18:26:01 +00:00
|
|
|
grub_printf_ (N_("System management bus controller I/O space is at 0x%x\n"),
|
|
|
|
smbbase);
|
2010-02-16 21:39:59 +00:00
|
|
|
|
|
|
|
for (i = GRUB_SMB_RAM_START_ADDR;
|
|
|
|
i < GRUB_SMB_RAM_START_ADDR + GRUB_SMB_RAM_NUM_MAX; i++)
|
|
|
|
{
|
|
|
|
struct grub_smbus_spd spd;
|
|
|
|
grub_memset (&spd, 0, sizeof (spd));
|
2012-02-26 16:28:05 +00:00
|
|
|
/* TRANSLATORS: it's shown in a report in a way
|
|
|
|
like number 1: ... number 2: ...
|
|
|
|
*/
|
2012-02-08 18:26:01 +00:00
|
|
|
grub_printf_ (N_("RAM slot number %d\n"), i);
|
2010-02-16 21:39:59 +00:00
|
|
|
err = grub_cs5536_read_spd (smbbase, i, &spd);
|
|
|
|
if (err)
|
|
|
|
{
|
|
|
|
grub_print_error ();
|
|
|
|
continue;
|
|
|
|
}
|
2011-11-11 23:34:14 +00:00
|
|
|
grub_printf_ (N_("Written SPD bytes: %d B.\n"), spd.written_size);
|
|
|
|
grub_printf_ (N_("Total flash size: %d B.\n"),
|
|
|
|
1 << spd.log_total_flash_size);
|
2010-02-16 21:39:59 +00:00
|
|
|
if (spd.memory_type == GRUB_SMBUS_SPD_MEMORY_TYPE_DDR2)
|
|
|
|
{
|
|
|
|
char str[sizeof (spd.ddr2.part_number) + 1];
|
2011-11-11 23:34:14 +00:00
|
|
|
grub_puts_ (N_("Memory type: DDR2."));
|
2010-02-16 21:39:59 +00:00
|
|
|
grub_memcpy (str, spd.ddr2.part_number,
|
|
|
|
sizeof (spd.ddr2.part_number));
|
|
|
|
str[sizeof (spd.ddr2.part_number)] = 0;
|
2011-11-11 23:34:14 +00:00
|
|
|
grub_printf_ (N_("Part no: %s.\n"), str);
|
2010-02-16 21:39:59 +00:00
|
|
|
}
|
|
|
|
else
|
2011-11-11 23:34:14 +00:00
|
|
|
grub_puts_ (N_("Memory type: Unknown."));
|
2010-02-16 21:39:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return GRUB_ERR_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static grub_command_t cmd;
|
|
|
|
|
|
|
|
GRUB_MOD_INIT(lsspd)
|
|
|
|
{
|
|
|
|
cmd = grub_register_command ("lsspd", grub_cmd_lsspd, 0,
|
2011-11-11 23:34:14 +00:00
|
|
|
N_("Print Memory information."));
|
2010-02-16 21:39:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
GRUB_MOD_FINI(lsspd)
|
|
|
|
{
|
|
|
|
grub_unregister_command (cmd);
|
|
|
|
}
|