~hamo/ubuntu/precise/grub2/grub2.hi_res

« back to all changes in this revision

Viewing changes to commands/mips/yeeloong/lsspd.c

Tags: upstream-1.98+20100705
ImportĀ upstreamĀ versionĀ 1.98+20100705

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 *  GRUB  --  GRand Unified Bootloader
 
3
 *  Copyright (C) 2010  Free Software Foundation, Inc.
 
4
 *
 
5
 *  GRUB is free software: you can redistribute it and/or modify
 
6
 *  it under the terms of the GNU General Public License as published by
 
7
 *  the Free Software Foundation, either version 3 of the License, or
 
8
 *  (at your option) any later version.
 
9
 *
 
10
 *  GRUB is distributed in the hope that it will be useful,
 
11
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
12
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
13
 *  GNU General Public License for more details.
 
14
 *
 
15
 *  You should have received a copy of the GNU General Public License
 
16
 *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 
17
 */
 
18
 
 
19
#include <grub/types.h>
 
20
#include <grub/misc.h>
 
21
#include <grub/mm.h>
 
22
#include <grub/err.h>
 
23
#include <grub/dl.h>
 
24
#include <grub/command.h>
 
25
#include <grub/cs5536.h>
 
26
 
 
27
static grub_err_t
 
28
grub_cmd_lsspd (grub_command_t cmd __attribute__ ((unused)),
 
29
                int argc __attribute__ ((unused)),
 
30
                char **args __attribute__ ((unused)))
 
31
{
 
32
  grub_pci_device_t dev;
 
33
  grub_port_t smbbase;
 
34
  int i;
 
35
  grub_err_t err;
 
36
 
 
37
  if (!grub_cs5536_find (&dev))
 
38
    {
 
39
      grub_printf ("No CS5536 found\n");
 
40
      return GRUB_ERR_NONE;
 
41
    }
 
42
  grub_printf ("CS5536 at %d:%d.%d\n", grub_pci_get_bus (dev),
 
43
               grub_pci_get_device (dev), grub_pci_get_function (dev));
 
44
  
 
45
  err = grub_cs5536_init_smbus (dev, 0x7fff, &smbbase);
 
46
  if (err)
 
47
    return err;
 
48
 
 
49
  grub_printf ("SMB base = 0x%x\n", smbbase);
 
50
 
 
51
  for (i = GRUB_SMB_RAM_START_ADDR;
 
52
       i < GRUB_SMB_RAM_START_ADDR + GRUB_SMB_RAM_NUM_MAX; i++)
 
53
    {
 
54
      struct grub_smbus_spd spd;
 
55
      grub_memset (&spd, 0, sizeof (spd));
 
56
      grub_printf ("Device %d\n", i);
 
57
      err = grub_cs5536_read_spd (smbbase, i, &spd);
 
58
      if (err)
 
59
        {
 
60
          grub_print_error ();
 
61
          continue;
 
62
        }
 
63
      grub_printf ("Written SPD bytes: %d B.\n", spd.written_size);
 
64
      grub_printf ("Total flash size: %d B.\n", 1 << spd.log_total_flash_size);
 
65
      if (spd.memory_type == GRUB_SMBUS_SPD_MEMORY_TYPE_DDR2)
 
66
        {
 
67
          char str[sizeof (spd.ddr2.part_number) + 1];
 
68
          grub_printf ("Memory type: DDR2.\n");
 
69
          grub_memcpy (str, spd.ddr2.part_number,
 
70
                       sizeof (spd.ddr2.part_number));
 
71
          str[sizeof (spd.ddr2.part_number)] = 0;
 
72
          grub_printf ("Part no: %s.\n", str);
 
73
        }
 
74
      else
 
75
        grub_printf ("Memory type: Unknown.\n");
 
76
    }
 
77
 
 
78
  return GRUB_ERR_NONE;
 
79
}
 
80
 
 
81
static grub_command_t cmd;
 
82
 
 
83
GRUB_MOD_INIT(lsspd)
 
84
{
 
85
  cmd = grub_register_command ("lsspd", grub_cmd_lsspd, 0,
 
86
                               "Print Memory information.");
 
87
}
 
88
 
 
89
GRUB_MOD_FINI(lsspd)
 
90
{
 
91
  grub_unregister_command (cmd);
 
92
}