blob: 26ee39ef77f9fbd10f0ef3333d2a83ce6e3ac1c3 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +05302/*
Tony Dinhac47bd22022-04-17 16:42:32 -07003 * Copyright (C) 2021-2022 Tony Dinh <mibodhi@gmail.com>
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +05304 * (C) Copyright 2009
5 * Marvell Semiconductor <www.marvell.com>
6 * Written-by: Prafulla Wadaskar <prafulla@marvell.com>
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +05307 */
8
9#include <common.h>
Simon Glass691d7192020-05-10 11:40:02 -060010#include <init.h>
Tony Dinhac47bd22022-04-17 16:42:32 -070011#include <netdev.h>
Simon Glass401d1c42020-10-30 21:38:53 -060012#include <asm/global_data.h>
Simon Glassc62db352017-05-31 19:47:48 -060013#include <asm/mach-types.h>
Lei Wena7efd712011-10-18 20:11:42 +053014#include <asm/arch/cpu.h>
Stefan Roese3dc23f72014-10-22 12:13:06 +020015#include <asm/arch/soc.h>
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +053016#include <asm/arch/mpp.h>
Tony Dinhac47bd22022-04-17 16:42:32 -070017#include <linux/bitops.h>
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +053018
19DECLARE_GLOBAL_DATA_PTR;
20
Tony Dinhac47bd22022-04-17 16:42:32 -070021#define SHEEVAPLUG_OE_LOW (~(0))
22#define SHEEVAPLUG_OE_HIGH (~(0))
23#define SHEEVAPLUG_OE_VAL_LOW BIT(29) /* USB_PWEN low */
24#define SHEEVAPLUG_OE_VAL_HIGH BIT(17) /* LED pin high */
25
Prafulla Wadaskar754ae3f2010-10-20 20:12:27 +053026int board_early_init_f(void)
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +053027{
28 /*
29 * default gpio configuration
30 * There are maximum 64 gpios controlled through 2 sets of registers
31 * the below configuration configures mainly initial LED status
32 */
Stefan Roesed5c51322014-10-22 12:13:11 +020033 mvebu_config_gpio(SHEEVAPLUG_OE_VAL_LOW,
34 SHEEVAPLUG_OE_VAL_HIGH,
35 SHEEVAPLUG_OE_LOW, SHEEVAPLUG_OE_HIGH);
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +053036
37 /* Multi-Purpose Pins Functionality configuration */
Albert ARIBAUD9d86f0c2012-11-26 11:27:36 +000038 static const u32 kwmpp_config[] = {
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +053039 MPP0_NF_IO2,
40 MPP1_NF_IO3,
41 MPP2_NF_IO4,
42 MPP3_NF_IO5,
43 MPP4_NF_IO6,
44 MPP5_NF_IO7,
45 MPP6_SYSRST_OUTn,
46 MPP7_GPO,
47 MPP8_UART0_RTS,
48 MPP9_UART0_CTS,
49 MPP10_UART0_TXD,
50 MPP11_UART0_RXD,
51 MPP12_SD_CLK,
52 MPP13_SD_CMD,
53 MPP14_SD_D0,
54 MPP15_SD_D1,
55 MPP16_SD_D2,
56 MPP17_SD_D3,
57 MPP18_NF_IO0,
58 MPP19_NF_IO1,
59 MPP20_GPIO,
60 MPP21_GPIO,
61 MPP22_GPIO,
62 MPP23_GPIO,
63 MPP24_GPIO,
64 MPP25_GPIO,
65 MPP26_GPIO,
66 MPP27_GPIO,
67 MPP28_GPIO,
68 MPP29_TSMP9,
69 MPP30_GPIO,
70 MPP31_GPIO,
71 MPP32_GPIO,
72 MPP33_GPIO,
73 MPP34_GPIO,
74 MPP35_GPIO,
75 MPP36_GPIO,
76 MPP37_GPIO,
77 MPP38_GPIO,
78 MPP39_GPIO,
79 MPP40_GPIO,
80 MPP41_GPIO,
81 MPP42_GPIO,
82 MPP43_GPIO,
83 MPP44_GPIO,
84 MPP45_GPIO,
85 MPP46_GPIO,
86 MPP47_GPIO,
87 MPP48_GPIO,
88 MPP49_GPIO,
89 0
90 };
Valentin Longchamp84683632012-06-01 01:31:00 +000091 kirkwood_mpp_conf(kwmpp_config, NULL);
Prafulla Wadaskar754ae3f2010-10-20 20:12:27 +053092 return 0;
93}
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +053094
Tony Dinhac47bd22022-04-17 16:42:32 -070095int board_eth_init(struct bd_info *bis)
96{
97 return cpu_eth_init(bis);
98}
99
Prafulla Wadaskar754ae3f2010-10-20 20:12:27 +0530100int board_init(void)
101{
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +0530102 /*
103 * arch number of board
104 */
105 gd->bd->bi_arch_number = MACH_TYPE_SHEEVAPLUG;
106
Tony Dinhac47bd22022-04-17 16:42:32 -0700107 /* address of boot parameters */
Stefan Roese96c5f082014-10-22 12:13:13 +0200108 gd->bd->bi_boot_params = mvebu_sdram_bar(0) + 0x100;
Prafulla Wadaskar55dd4ba2009-07-16 20:58:00 +0530109
110 return 0;
111}