Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
57475b1a
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
57475b1a
编写于
2月 08, 2010
作者:
S
Simon Guinot
提交者:
Nicolas Pitre
5月 03, 2010
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[ARM] Kirkwood: merge net2big_v2 and net5big_v2 board setups
Signed-off-by:
N
Nicolas Pitre
<
nico@fluxnic.net
>
上级
3e05ec1b
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
120 addition
and
394 deletion
+120
-394
arch/arm/mach-kirkwood/Makefile
arch/arm/mach-kirkwood/Makefile
+2
-2
arch/arm/mach-kirkwood/net2big_v2-setup.c
arch/arm/mach-kirkwood/net2big_v2-setup.c
+0
-334
arch/arm/mach-kirkwood/netxbig_v2-setup.c
arch/arm/mach-kirkwood/netxbig_v2-setup.c
+118
-58
未找到文件。
arch/arm/mach-kirkwood/Makefile
浏览文件 @
57475b1a
...
...
@@ -12,7 +12,7 @@ obj-$(CONFIG_MACH_TS41X) += ts41x-setup.o tsx1x-common.o
obj-$(CONFIG_MACH_OPENRD)
+=
openrd-setup.o
obj-$(CONFIG_MACH_NETSPACE_V2)
+=
netspace_v2-setup.o
obj-$(CONFIG_MACH_INETSPACE_V2)
+=
netspace_v2-setup.o
obj-$(CONFIG_MACH_NET2BIG_V2)
+=
net
2
big_v2-setup.o
obj-$(CONFIG_MACH_NET5BIG_V2)
+=
net
5
big_v2-setup.o
obj-$(CONFIG_MACH_NET2BIG_V2)
+=
net
x
big_v2-setup.o
obj-$(CONFIG_MACH_NET5BIG_V2)
+=
net
x
big_v2-setup.o
obj-$(CONFIG_CPU_IDLE)
+=
cpuidle.o
arch/arm/mach-kirkwood/net2big_v2-setup.c
已删除
100644 → 0
浏览文件 @
3e05ec1b
/*
* arch/arm/mach-kirkwood/net2big_v2-setup.c
*
* LaCie 2Big Network v2 board setup
*
* Copyright (C) 2010 Simon Guinot <sguinot@lacie.com>
*
* This program 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 2 of the License, or
* (at your option) any later version.
*
* This program 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 this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/platform_device.h>
#include <linux/mtd/physmap.h>
#include <linux/spi/flash.h>
#include <linux/spi/spi.h>
#include <linux/ata_platform.h>
#include <linux/mv643xx_eth.h>
#include <linux/i2c.h>
#include <linux/i2c/at24.h>
#include <linux/input.h>
#include <linux/gpio.h>
#include <linux/gpio_keys.h>
#include <linux/leds.h>
#include <asm/mach-types.h>
#include <asm/mach/arch.h>
#include <asm/mach/time.h>
#include <mach/kirkwood.h>
#include <plat/time.h>
#include "common.h"
#include "mpp.h"
/*****************************************************************************
* 512KB SPI Flash on Boot Device (MACRONIX MX25L4005)
****************************************************************************/
static
struct
mtd_partition
net2big_v2_flash_parts
[]
=
{
{
.
name
=
"u-boot"
,
.
size
=
MTDPART_SIZ_FULL
,
.
offset
=
0
,
.
mask_flags
=
MTD_WRITEABLE
,
/* force read-only */
},
};
static
const
struct
flash_platform_data
net2big_v2_flash
=
{
.
type
=
"mx25l4005a"
,
.
name
=
"spi_flash"
,
.
parts
=
net2big_v2_flash_parts
,
.
nr_parts
=
ARRAY_SIZE
(
net2big_v2_flash_parts
),
};
static
struct
spi_board_info
__initdata
net2big_v2_spi_slave_info
[]
=
{
{
.
modalias
=
"m25p80"
,
.
platform_data
=
&
net2big_v2_flash
,
.
irq
=
-
1
,
.
max_speed_hz
=
20000000
,
.
bus_num
=
0
,
.
chip_select
=
0
,
},
};
/*****************************************************************************
* Ethernet
****************************************************************************/
static
struct
mv643xx_eth_platform_data
net2big_v2_ge00_data
=
{
.
phy_addr
=
MV643XX_ETH_PHY_ADDR
(
8
),
};
/*****************************************************************************
* I2C devices
****************************************************************************/
static
struct
at24_platform_data
at24c04
=
{
.
byte_len
=
SZ_4K
/
8
,
.
page_size
=
16
,
};
/*
* i2c addr | chip | description
* 0x50 | HT24LC04 | eeprom (512B)
*/
static
struct
i2c_board_info
__initdata
net2big_v2_i2c_info
[]
=
{
{
I2C_BOARD_INFO
(
"24c04"
,
0x50
),
.
platform_data
=
&
at24c04
,
}
};
/*****************************************************************************
* SATA
****************************************************************************/
static
struct
mv_sata_platform_data
net2big_v2_sata_data
=
{
.
n_ports
=
2
,
};
static
int
__initdata
net2big_v2_gpio_hdd_power
[]
=
{
16
,
17
};
static
void
__init
net2big_v2_sata_power_init
(
void
)
{
int
i
;
int
err
;
/* Power up all hard disks. */
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
net2big_v2_gpio_hdd_power
);
i
++
)
{
err
=
gpio_request
(
net2big_v2_gpio_hdd_power
[
i
],
NULL
);
if
(
err
==
0
)
{
err
=
gpio_direction_output
(
net2big_v2_gpio_hdd_power
[
i
],
1
);
/* Free the HDD power GPIOs. This allow user-space to
* configure them via the gpiolib sysfs interface. */
gpio_free
(
net2big_v2_gpio_hdd_power
[
i
]);
}
if
(
err
)
pr_err
(
"net2big_v2: failed to power-up HDD%d
\n
"
,
i
+
1
);
}
}
/*****************************************************************************
* GPIO keys
****************************************************************************/
#define NET2BIG_V2_GPIO_SWITCH_POWER_ON 13
#define NET2BIG_V2_GPIO_SWITCH_POWER_OFF 15
#define NET2BIG_V2_GPIO_FUNC_BUTTON 34
#define NET2BIG_V2_SWITCH_POWER_ON 0x1
#define NET2BIG_V2_SWITCH_POWER_OFF 0x2
static
struct
gpio_keys_button
net2big_v2_buttons
[]
=
{
[
0
]
=
{
.
type
=
EV_SW
,
.
code
=
NET2BIG_V2_SWITCH_POWER_ON
,
.
gpio
=
NET2BIG_V2_GPIO_SWITCH_POWER_ON
,
.
desc
=
"Back power switch (on|auto)"
,
.
active_low
=
1
,
},
[
1
]
=
{
.
type
=
EV_SW
,
.
code
=
NET2BIG_V2_SWITCH_POWER_OFF
,
.
gpio
=
NET2BIG_V2_GPIO_SWITCH_POWER_OFF
,
.
desc
=
"Back power switch (auto|off)"
,
.
active_low
=
1
,
},
[
2
]
=
{
.
code
=
KEY_OPTION
,
.
gpio
=
NET2BIG_V2_GPIO_FUNC_BUTTON
,
.
desc
=
"Function button"
,
.
active_low
=
1
,
},
};
static
struct
gpio_keys_platform_data
net2big_v2_button_data
=
{
.
buttons
=
net2big_v2_buttons
,
.
nbuttons
=
ARRAY_SIZE
(
net2big_v2_buttons
),
};
static
struct
platform_device
net2big_v2_gpio_buttons
=
{
.
name
=
"gpio-keys"
,
.
id
=
-
1
,
.
dev
=
{
.
platform_data
=
&
net2big_v2_button_data
,
},
};
/*****************************************************************************
* GPIO LEDs
****************************************************************************/
/*
* The LEDs are controlled by a CPLD and can be configured through a GPIO
* extension bus:
*
* - address register : bit [0-2] -> GPIO [47-49]
* - data register : bit [0-2] -> GPIO [44-46]
* - enable register : GPIO 29
*
* Address register selection:
*
* addr | register
* ----------------------------
* 0 | front LED
* 1 | front LED brightness
* 2 | HDD LED brightness
* 3 | HDD1 LED
* 4 | HDD2 LED
*
* Data register configuration:
*
* data | LED brightness
* -------------------------------------------------
* 0 | min (off)
* - | -
* 7 | max
*
* data | front LED mode
* -------------------------------------------------
* 0 | fix off
* 1 | fix blue on
* 2 | fix red on
* 3 | blink blue on=1 sec and blue off=1 sec
* 4 | blink red on=1 sec and red off=1 sec
* 5 | blink blue on=2.5 sec and red on=0.5 sec
* 6 | blink blue on=1 sec and red on=1 sec
* 7 | blink blue on=0.5 sec and blue off=2.5 sec
*
* data | HDD LED mode
* -------------------------------------------------
* 0 | fix blue on
* 1 | SATA activity blink
* 2 | fix red on
* 3 | blink blue on=1 sec and blue off=1 sec
* 4 | blink red on=1 sec and red off=1 sec
* 5 | blink blue on=2.5 sec and red on=0.5 sec
* 6 | blink blue on=1 sec and red on=1 sec
* 7 | blink blue on=0.5 sec and blue off=2.5 sec
*/
/*****************************************************************************
* Timer
****************************************************************************/
static
void
net2big_v2_timer_init
(
void
)
{
kirkwood_tclk
=
166666667
;
orion_time_init
(
IRQ_KIRKWOOD_BRIDGE
,
kirkwood_tclk
);
}
struct
sys_timer
net2big_v2_timer
=
{
.
init
=
net2big_v2_timer_init
,
};
/*****************************************************************************
* General Setup
****************************************************************************/
static
unsigned
int
net2big_v2_mpp_config
[]
__initdata
=
{
MPP0_SPI_SCn
,
MPP1_SPI_MOSI
,
MPP2_SPI_SCK
,
MPP3_SPI_MISO
,
MPP6_SYSRST_OUTn
,
MPP7_GPO
,
/* Request power-off */
MPP8_TW_SDA
,
MPP9_TW_SCK
,
MPP10_UART0_TXD
,
MPP11_UART0_RXD
,
MPP13_GPIO
,
/* Rear power switch (on|auto) */
MPP14_GPIO
,
/* USB fuse alarm */
MPP15_GPIO
,
/* Rear power switch (auto|off) */
MPP16_GPIO
,
/* SATA HDD1 power */
MPP17_GPIO
,
/* SATA HDD2 power */
MPP20_SATA1_ACTn
,
MPP21_SATA0_ACTn
,
MPP24_GPIO
,
/* USB mode select */
MPP26_GPIO
,
/* USB device vbus */
MPP28_GPIO
,
/* USB enable host vbus */
MPP29_GPIO
,
/* GPIO extension ALE */
MPP34_GPIO
,
/* Rear Push button */
MPP35_GPIO
,
/* Inhibit switch power-off */
MPP36_GPIO
,
/* SATA HDD1 presence */
MPP37_GPIO
,
/* SATA HDD2 presence */
MPP40_GPIO
,
/* eSATA presence */
MPP44_GPIO
,
/* GPIO extension (data 0) */
MPP45_GPIO
,
/* GPIO extension (data 1) */
MPP46_GPIO
,
/* GPIO extension (data 2) */
MPP47_GPIO
,
/* GPIO extension (addr 0) */
MPP48_GPIO
,
/* GPIO extension (addr 1) */
MPP49_GPIO
,
/* GPIO extension (addr 2) */
0
};
#define NET2BIG_V2_GPIO_POWER_OFF 7
static
void
net2big_v2_power_off
(
void
)
{
gpio_set_value
(
NET2BIG_V2_GPIO_POWER_OFF
,
1
);
}
static
void
__init
net2big_v2_init
(
void
)
{
/*
* Basic setup. Needs to be called early.
*/
kirkwood_init
();
kirkwood_mpp_conf
(
net2big_v2_mpp_config
);
net2big_v2_sata_power_init
();
kirkwood_ehci_init
();
kirkwood_ge00_init
(
&
net2big_v2_ge00_data
);
kirkwood_sata_init
(
&
net2big_v2_sata_data
);
kirkwood_uart0_init
();
spi_register_board_info
(
net2big_v2_spi_slave_info
,
ARRAY_SIZE
(
net2big_v2_spi_slave_info
));
kirkwood_spi_init
();
kirkwood_i2c_init
();
i2c_register_board_info
(
0
,
net2big_v2_i2c_info
,
ARRAY_SIZE
(
net2big_v2_i2c_info
));
platform_device_register
(
&
net2big_v2_gpio_buttons
);
if
(
gpio_request
(
NET2BIG_V2_GPIO_POWER_OFF
,
"power-off"
)
==
0
&&
gpio_direction_output
(
NET2BIG_V2_GPIO_POWER_OFF
,
0
)
==
0
)
pm_power_off
=
net2big_v2_power_off
;
else
pr_err
(
"net2big_v2: failed to configure power-off GPIO
\n
"
);
}
MACHINE_START
(
NET2BIG_V2
,
"LaCie 2Big Network v2"
)
.
phys_io
=
KIRKWOOD_REGS_PHYS_BASE
,
.
io_pg_offst
=
((
KIRKWOOD_REGS_VIRT_BASE
)
>>
18
)
&
0xfffc
,
.
boot_params
=
0x00000100
,
.
init_machine
=
net2big_v2_init
,
.
map_io
=
kirkwood_map_io
,
.
init_irq
=
kirkwood_init_irq
,
.
timer
=
&
net2big_v2_timer
,
MACHINE_END
arch/arm/mach-kirkwood/net
5
big_v2-setup.c
→
arch/arm/mach-kirkwood/net
x
big_v2-setup.c
浏览文件 @
57475b1a
/*
* arch/arm/mach-kirkwood/net
5
big_v2-setup.c
* arch/arm/mach-kirkwood/net
x
big_v2-setup.c
*
* LaCie 5Big Network v2 board setup
* LaCie
2Big and
5Big Network v2 board setup
*
* Copyright (C) 2010 Simon Guinot <sguinot@lacie.com>
*
...
...
@@ -46,7 +46,7 @@
* 512KB SPI Flash on Boot Device (MACRONIX MX25L4005)
****************************************************************************/
static
struct
mtd_partition
net
5
big_v2_flash_parts
[]
=
{
static
struct
mtd_partition
net
x
big_v2_flash_parts
[]
=
{
{
.
name
=
"u-boot"
,
.
size
=
MTDPART_SIZ_FULL
,
...
...
@@ -55,17 +55,17 @@ static struct mtd_partition net5big_v2_flash_parts[] = {
},
};
static
const
struct
flash_platform_data
net
5
big_v2_flash
=
{
static
const
struct
flash_platform_data
net
x
big_v2_flash
=
{
.
type
=
"mx25l4005a"
,
.
name
=
"spi_flash"
,
.
parts
=
net
5
big_v2_flash_parts
,
.
nr_parts
=
ARRAY_SIZE
(
net
5
big_v2_flash_parts
),
.
parts
=
net
x
big_v2_flash_parts
,
.
nr_parts
=
ARRAY_SIZE
(
net
x
big_v2_flash_parts
),
};
static
struct
spi_board_info
__initdata
net
5
big_v2_spi_slave_info
[]
=
{
static
struct
spi_board_info
__initdata
net
x
big_v2_spi_slave_info
[]
=
{
{
.
modalias
=
"m25p80"
,
.
platform_data
=
&
net
5
big_v2_flash
,
.
platform_data
=
&
net
x
big_v2_flash
,
.
irq
=
-
1
,
.
max_speed_hz
=
20000000
,
.
bus_num
=
0
,
...
...
@@ -77,11 +77,11 @@ static struct spi_board_info __initdata net5big_v2_spi_slave_info[] = {
* Ethernet
****************************************************************************/
static
struct
mv643xx_eth_platform_data
net
5
big_v2_ge00_data
=
{
static
struct
mv643xx_eth_platform_data
net
x
big_v2_ge00_data
=
{
.
phy_addr
=
MV643XX_ETH_PHY_ADDR
(
8
),
};
static
struct
mv643xx_eth_platform_data
net
5
big_v2_ge01_data
=
{
static
struct
mv643xx_eth_platform_data
net
x
big_v2_ge01_data
=
{
.
phy_addr
=
MV643XX_ETH_PHY_ADDR
(
0
),
};
...
...
@@ -99,7 +99,7 @@ static struct at24_platform_data at24c04 = {
* 0x50 | HT24LC04 | eeprom (512B)
*/
static
struct
i2c_board_info
__initdata
net
5
big_v2_i2c_info
[]
=
{
static
struct
i2c_board_info
__initdata
net
x
big_v2_i2c_info
[]
=
{
{
I2C_BOARD_INFO
(
"24c04"
,
0x50
),
.
platform_data
=
&
at24c04
,
...
...
@@ -110,29 +110,35 @@ static struct i2c_board_info __initdata net5big_v2_i2c_info[] = {
* SATA
****************************************************************************/
static
struct
mv_sata_platform_data
net
5
big_v2_sata_data
=
{
static
struct
mv_sata_platform_data
net
x
big_v2_sata_data
=
{
.
n_ports
=
2
,
};
static
int
__initdata
net
5
big_v2_gpio_hdd_power
[]
=
{
16
,
17
,
41
,
42
,
43
};
static
int
__initdata
net
x
big_v2_gpio_hdd_power
[]
=
{
16
,
17
,
41
,
42
,
43
};
static
void
__init
net
5
big_v2_sata_power_init
(
void
)
static
void
__init
net
x
big_v2_sata_power_init
(
void
)
{
int
i
;
int
err
;
int
hdd_nb
;
if
(
machine_is_net2big_v2
())
hdd_nb
=
2
;
else
hdd_nb
=
5
;
/* Power up all hard disks. */
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
net5big_v2_gpio_hdd_power
)
;
i
++
)
{
err
=
gpio_request
(
net
5
big_v2_gpio_hdd_power
[
i
],
NULL
);
for
(
i
=
0
;
i
<
hdd_nb
;
i
++
)
{
err
=
gpio_request
(
net
x
big_v2_gpio_hdd_power
[
i
],
NULL
);
if
(
err
==
0
)
{
err
=
gpio_direction_output
(
net
5
big_v2_gpio_hdd_power
[
i
],
1
);
net
x
big_v2_gpio_hdd_power
[
i
],
1
);
/* Free the HDD power GPIOs. This allow user-space to
* configure them via the gpiolib sysfs interface. */
gpio_free
(
net
5
big_v2_gpio_hdd_power
[
i
]);
gpio_free
(
net
x
big_v2_gpio_hdd_power
[
i
]);
}
if
(
err
)
pr_err
(
"net
5
big_v2: failed to power up HDD%d
\n
"
,
i
+
1
);
pr_err
(
"net
x
big_v2: failed to power up HDD%d
\n
"
,
i
+
1
);
}
}
...
...
@@ -140,46 +146,46 @@ static void __init net5big_v2_sata_power_init(void)
* GPIO keys
****************************************************************************/
#define NET
5
BIG_V2_GPIO_SWITCH_POWER_ON 13
#define NET
5
BIG_V2_GPIO_SWITCH_POWER_OFF 15
#define NET
5
BIG_V2_GPIO_FUNC_BUTTON 34
#define NET
X
BIG_V2_GPIO_SWITCH_POWER_ON 13
#define NET
X
BIG_V2_GPIO_SWITCH_POWER_OFF 15
#define NET
X
BIG_V2_GPIO_FUNC_BUTTON 34
#define NET
5
BIG_V2_SWITCH_POWER_ON 0x1
#define NET
5
BIG_V2_SWITCH_POWER_OFF 0x2
#define NET
X
BIG_V2_SWITCH_POWER_ON 0x1
#define NET
X
BIG_V2_SWITCH_POWER_OFF 0x2
static
struct
gpio_keys_button
net
5
big_v2_buttons
[]
=
{
static
struct
gpio_keys_button
net
x
big_v2_buttons
[]
=
{
[
0
]
=
{
.
type
=
EV_SW
,
.
code
=
NET
5
BIG_V2_SWITCH_POWER_ON
,
.
gpio
=
NET
5
BIG_V2_GPIO_SWITCH_POWER_ON
,
.
code
=
NET
X
BIG_V2_SWITCH_POWER_ON
,
.
gpio
=
NET
X
BIG_V2_GPIO_SWITCH_POWER_ON
,
.
desc
=
"Back power switch (on|auto)"
,
.
active_low
=
1
,
},
[
1
]
=
{
.
type
=
EV_SW
,
.
code
=
NET
5
BIG_V2_SWITCH_POWER_OFF
,
.
gpio
=
NET
5
BIG_V2_GPIO_SWITCH_POWER_OFF
,
.
code
=
NET
X
BIG_V2_SWITCH_POWER_OFF
,
.
gpio
=
NET
X
BIG_V2_GPIO_SWITCH_POWER_OFF
,
.
desc
=
"Back power switch (auto|off)"
,
.
active_low
=
1
,
},
[
2
]
=
{
.
code
=
KEY_OPTION
,
.
gpio
=
NET
5
BIG_V2_GPIO_FUNC_BUTTON
,
.
gpio
=
NET
X
BIG_V2_GPIO_FUNC_BUTTON
,
.
desc
=
"Function button"
,
.
active_low
=
1
,
},
};
static
struct
gpio_keys_platform_data
net
5
big_v2_button_data
=
{
.
buttons
=
net
5
big_v2_buttons
,
.
nbuttons
=
ARRAY_SIZE
(
net
5
big_v2_buttons
),
static
struct
gpio_keys_platform_data
net
x
big_v2_button_data
=
{
.
buttons
=
net
x
big_v2_buttons
,
.
nbuttons
=
ARRAY_SIZE
(
net
x
big_v2_buttons
),
};
static
struct
platform_device
net
5
big_v2_gpio_buttons
=
{
static
struct
platform_device
net
x
big_v2_gpio_buttons
=
{
.
name
=
"gpio-keys"
,
.
id
=
-
1
,
.
dev
=
{
.
platform_data
=
&
net
5
big_v2_button_data
,
.
platform_data
=
&
net
x
big_v2_button_data
,
},
};
...
...
@@ -243,20 +249,56 @@ static struct platform_device net5big_v2_gpio_buttons = {
* Timer
****************************************************************************/
static
void
net
5
big_v2_timer_init
(
void
)
static
void
net
x
big_v2_timer_init
(
void
)
{
kirkwood_tclk
=
166666667
;
orion_time_init
(
IRQ_KIRKWOOD_BRIDGE
,
kirkwood_tclk
);
}
struct
sys_timer
net
5
big_v2_timer
=
{
.
init
=
net
5
big_v2_timer_init
,
struct
sys_timer
net
x
big_v2_timer
=
{
.
init
=
net
x
big_v2_timer_init
,
};
/*****************************************************************************
* General Setup
****************************************************************************/
static
unsigned
int
net2big_v2_mpp_config
[]
__initdata
=
{
MPP0_SPI_SCn
,
MPP1_SPI_MOSI
,
MPP2_SPI_SCK
,
MPP3_SPI_MISO
,
MPP6_SYSRST_OUTn
,
MPP7_GPO
,
/* Request power-off */
MPP8_TW_SDA
,
MPP9_TW_SCK
,
MPP10_UART0_TXD
,
MPP11_UART0_RXD
,
MPP13_GPIO
,
/* Rear power switch (on|auto) */
MPP14_GPIO
,
/* USB fuse alarm */
MPP15_GPIO
,
/* Rear power switch (auto|off) */
MPP16_GPIO
,
/* SATA HDD1 power */
MPP17_GPIO
,
/* SATA HDD2 power */
MPP20_SATA1_ACTn
,
MPP21_SATA0_ACTn
,
MPP24_GPIO
,
/* USB mode select */
MPP26_GPIO
,
/* USB device vbus */
MPP28_GPIO
,
/* USB enable host vbus */
MPP29_GPIO
,
/* CPLD extension ALE */
MPP34_GPIO
,
/* Rear Push button */
MPP35_GPIO
,
/* Inhibit switch power-off */
MPP36_GPIO
,
/* SATA HDD1 presence */
MPP37_GPIO
,
/* SATA HDD2 presence */
MPP40_GPIO
,
/* eSATA presence */
MPP44_GPIO
,
/* CPLD extension (data 0) */
MPP45_GPIO
,
/* CPLD extension (data 1) */
MPP46_GPIO
,
/* CPLD extension (data 2) */
MPP47_GPIO
,
/* CPLD extension (addr 0) */
MPP48_GPIO
,
/* CPLD extension (addr 1) */
MPP49_GPIO
,
/* CPLD extension (addr 2) */
0
};
static
unsigned
int
net5big_v2_mpp_config
[]
__initdata
=
{
MPP0_SPI_SCn
,
MPP1_SPI_MOSI
,
...
...
@@ -306,50 +348,68 @@ static unsigned int net5big_v2_mpp_config[] __initdata = {
0
};
#define NET
5
BIG_V2_GPIO_POWER_OFF 7
#define NET
X
BIG_V2_GPIO_POWER_OFF 7
static
void
net
5
big_v2_power_off
(
void
)
static
void
net
x
big_v2_power_off
(
void
)
{
gpio_set_value
(
NET
5
BIG_V2_GPIO_POWER_OFF
,
1
);
gpio_set_value
(
NET
X
BIG_V2_GPIO_POWER_OFF
,
1
);
}
static
void
__init
net
5
big_v2_init
(
void
)
static
void
__init
net
x
big_v2_init
(
void
)
{
/*
* Basic setup. Needs to be called early.
*/
kirkwood_init
();
kirkwood_mpp_conf
(
net5big_v2_mpp_config
);
if
(
machine_is_net2big_v2
())
kirkwood_mpp_conf
(
net2big_v2_mpp_config
);
else
kirkwood_mpp_conf
(
net5big_v2_mpp_config
);
net
5
big_v2_sata_power_init
();
net
x
big_v2_sata_power_init
();
kirkwood_ehci_init
();
kirkwood_ge00_init
(
&
net5big_v2_ge00_data
);
kirkwood_ge01_init
(
&
net5big_v2_ge01_data
);
kirkwood_sata_init
(
&
net5big_v2_sata_data
);
kirkwood_ge00_init
(
&
netxbig_v2_ge00_data
);
if
(
machine_is_net5big_v2
())
kirkwood_ge01_init
(
&
netxbig_v2_ge01_data
);
kirkwood_sata_init
(
&
netxbig_v2_sata_data
);
kirkwood_uart0_init
();
spi_register_board_info
(
net
5
big_v2_spi_slave_info
,
ARRAY_SIZE
(
net
5
big_v2_spi_slave_info
));
spi_register_board_info
(
net
x
big_v2_spi_slave_info
,
ARRAY_SIZE
(
net
x
big_v2_spi_slave_info
));
kirkwood_spi_init
();
kirkwood_i2c_init
();
i2c_register_board_info
(
0
,
net
5
big_v2_i2c_info
,
ARRAY_SIZE
(
net
5
big_v2_i2c_info
));
i2c_register_board_info
(
0
,
net
x
big_v2_i2c_info
,
ARRAY_SIZE
(
net
x
big_v2_i2c_info
));
platform_device_register
(
&
net
5
big_v2_gpio_buttons
);
platform_device_register
(
&
net
x
big_v2_gpio_buttons
);
if
(
gpio_request
(
NET
5
BIG_V2_GPIO_POWER_OFF
,
"power-off"
)
==
0
&&
gpio_direction_output
(
NET
5
BIG_V2_GPIO_POWER_OFF
,
0
)
==
0
)
pm_power_off
=
net
5
big_v2_power_off
;
if
(
gpio_request
(
NET
X
BIG_V2_GPIO_POWER_OFF
,
"power-off"
)
==
0
&&
gpio_direction_output
(
NET
X
BIG_V2_GPIO_POWER_OFF
,
0
)
==
0
)
pm_power_off
=
net
x
big_v2_power_off
;
else
pr_err
(
"net
5
big_v2: failed to configure power-off GPIO
\n
"
);
pr_err
(
"net
x
big_v2: failed to configure power-off GPIO
\n
"
);
}
#ifdef CONFIG_MACH_NET2BIG_V2
MACHINE_START
(
NET2BIG_V2
,
"LaCie 2Big Network v2"
)
.
phys_io
=
KIRKWOOD_REGS_PHYS_BASE
,
.
io_pg_offst
=
((
KIRKWOOD_REGS_VIRT_BASE
)
>>
18
)
&
0xfffc
,
.
boot_params
=
0x00000100
,
.
init_machine
=
netxbig_v2_init
,
.
map_io
=
kirkwood_map_io
,
.
init_irq
=
kirkwood_init_irq
,
.
timer
=
&
netxbig_v2_timer
,
MACHINE_END
#endif
#ifdef CONFIG_MACH_NET5BIG_V2
MACHINE_START
(
NET5BIG_V2
,
"LaCie 5Big Network v2"
)
.
phys_io
=
KIRKWOOD_REGS_PHYS_BASE
,
.
io_pg_offst
=
((
KIRKWOOD_REGS_VIRT_BASE
)
>>
18
)
&
0xfffc
,
.
boot_params
=
0x00000100
,
.
init_machine
=
net
5
big_v2_init
,
.
init_machine
=
net
x
big_v2_init
,
.
map_io
=
kirkwood_map_io
,
.
init_irq
=
kirkwood_init_irq
,
.
timer
=
&
net
5
big_v2_timer
,
.
timer
=
&
net
x
big_v2_timer
,
MACHINE_END
#endif
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录