blob: d680f97c553f87432663f13e610ee8fc36f86714 [file] [log] [blame]
Carl-Daniel Hailfingerb5b161b2010-06-04 19:05:39 +00001/*
2 * This file is part of the flashrom project.
3 *
4 * Copyright (C) 2010 Carl-Daniel Hailfinger
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; version 2 of the License.
9 *
10 * This program 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 this program; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18 */
19
20/*
21 * Contains the processor specific flash enables and system settings.
22 */
23
24#include "flash.h"
Carl-Daniel Hailfinger5b997c32010-07-27 22:41:39 +000025#include "programmer.h"
Carl-Daniel Hailfingerb5b161b2010-06-04 19:05:39 +000026
27#if defined(__i386__) || defined(__x86_64__)
28
29int processor_flash_enable(void)
30{
31 /* On x86, flash access is not processor specific except on
32 * AMD Elan SC520, AMD Geode and maybe other SoC-style CPUs.
33 * FIXME: Move enable_flash_cs5536 and get_flashbase_sc520 here.
34 */
35 return 0;
36}
37
38#else
39
Vladimir 'phcoder' Serbinenko5cfc94a2010-09-29 23:37:24 +000040#if defined (__MIPSEL__) && defined (__linux)
41#include <stdio.h>
42#include <string.h>
43#include <ctype.h>
44
45static int is_loongson(void)
46{
47 FILE *cpuinfo;
48 cpuinfo = fopen("/proc/cpuinfo", "rb");
49 if (!cpuinfo)
50 return 0;
51 while (!feof(cpuinfo)) {
52 char line[512], *ptr;
53 if (fgets(line, sizeof(line), cpuinfo) == NULL)
54 break;
55 ptr = line;
Carl-Daniel Hailfinger9e3a6c42010-10-08 12:40:09 +000056 while (*ptr && isspace((unsigned char)*ptr))
Vladimir 'phcoder' Serbinenko5cfc94a2010-09-29 23:37:24 +000057 ptr++;
58 /* "cpu" part appears only with some Linux versions. */
Carl-Daniel Hailfingerbfa021d2011-06-26 11:50:10 +000059 if (strncmp(ptr, "cpu", strlen("cpu")) == 0)
60 ptr += strlen("cpu");
Carl-Daniel Hailfinger9e3a6c42010-10-08 12:40:09 +000061 while (*ptr && isspace((unsigned char)*ptr))
Vladimir 'phcoder' Serbinenko5cfc94a2010-09-29 23:37:24 +000062 ptr++;
Carl-Daniel Hailfingerbfa021d2011-06-26 11:50:10 +000063 if (strncmp(ptr, "model", strlen("model")) != 0)
Vladimir 'phcoder' Serbinenko5cfc94a2010-09-29 23:37:24 +000064 continue;
Carl-Daniel Hailfingerbfa021d2011-06-26 11:50:10 +000065 ptr += strlen("model");
Carl-Daniel Hailfinger9e3a6c42010-10-08 12:40:09 +000066 while (*ptr && isspace((unsigned char)*ptr))
Vladimir 'phcoder' Serbinenko5cfc94a2010-09-29 23:37:24 +000067 ptr++;
68 if (*ptr != ':')
69 continue;
70 ptr++;
Carl-Daniel Hailfinger9e3a6c42010-10-08 12:40:09 +000071 while (*ptr && isspace((unsigned char)*ptr))
Vladimir 'phcoder' Serbinenko5cfc94a2010-09-29 23:37:24 +000072 ptr++;
73 fclose(cpuinfo);
74 return (strncmp(ptr, "ICT Loongson-2 V0.3",
Carl-Daniel Hailfingerbfa021d2011-06-26 11:50:10 +000075 strlen("ICT Loongson-2 V0.3")) == 0)
Vladimir 'phcoder' Serbinenko5cfc94a2010-09-29 23:37:24 +000076 || (strncmp(ptr, "Godson2 V0.3 FPU V0.1",
Carl-Daniel Hailfingerbfa021d2011-06-26 11:50:10 +000077 strlen("Godson2 V0.3 FPU V0.1")) == 0);
Vladimir 'phcoder' Serbinenko5cfc94a2010-09-29 23:37:24 +000078 }
79 fclose(cpuinfo);
80 return 0;
81}
82#endif
83
Carl-Daniel Hailfingerb5b161b2010-06-04 19:05:39 +000084int processor_flash_enable(void)
85{
Vladimir 'phcoder' Serbinenko5cfc94a2010-09-29 23:37:24 +000086 /* FIXME: detect loongson on FreeBSD and OpenBSD as well. */
87#if defined (__MIPSEL__) && defined (__linux)
88 if (is_loongson()) {
89 flashbase = 0x1fc00000;
90 return 0;
91 }
92#endif
Carl-Daniel Hailfingerb5b161b2010-06-04 19:05:39 +000093 /* Not implemented yet. Oh well. */
94 return 1;
95}
96
97#endif