blob: bdd5fcd76ae8d77aedf469430d7f733e874a89f1 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Marek Vasut189e35b2013-01-12 07:11:11 +00002/*
3 * Olimex MX23 Olinuxino board
4 *
5 * Copyright (C) 2013 Marek Vasut <marex@denx.de>
Marek Vasut189e35b2013-01-12 07:11:11 +00006 */
7
Tom Riniabb9a042024-05-18 20:20:43 -06008#include <common.h>
Simon Glass97589732020-05-10 11:40:02 -06009#include <init.h>
Simon Glass3ba929a2020-10-30 21:38:53 -060010#include <asm/global_data.h>
Otavio Salvador3600ec32013-03-07 07:32:53 +000011#include <asm/gpio.h>
Marek Vasut73f2b032013-01-22 15:01:05 +000012#include <asm/io.h>
13#include <asm/arch/iomux-mx23.h>
Marek Vasut189e35b2013-01-12 07:11:11 +000014#include <asm/arch/imx-regs.h>
Marek Vasut73f2b032013-01-22 15:01:05 +000015#include <asm/arch/clock.h>
Marek Vasut189e35b2013-01-12 07:11:11 +000016#include <asm/arch/sys_proto.h>
Uri Mashiach4892d392017-01-19 10:51:45 +020017#ifdef CONFIG_LED_STATUS
Otavio Salvadorfcc76892013-02-23 02:43:09 +000018#include <status_led.h>
19#endif
Simon Glassdbd79542020-05-10 11:40:11 -060020#include <linux/delay.h>
Marek Vasut189e35b2013-01-12 07:11:11 +000021
22DECLARE_GLOBAL_DATA_PTR;
23
24/*
25 * Functions
26 */
27int board_early_init_f(void)
28{
Marek Vasut73f2b032013-01-22 15:01:05 +000029 /* IO0 clock at 480MHz */
30 mxs_set_ioclk(MXC_IOCLK0, 480000);
31
32 /* SSP0 clock at 96MHz */
33 mxs_set_sspclk(MXC_SSPCLK0, 96000, 0);
34
Marek Vasut3f302a72014-04-28 03:38:42 +020035 return 0;
36}
37
Otavio Salvador801fa152013-03-02 05:17:29 +000038#ifdef CONFIG_CMD_USB
Marek Vasut3f302a72014-04-28 03:38:42 +020039int board_ehci_hcd_init(int port)
40{
41 /* Enable LAN9512 (Maxi) or GL850G (Mini) USB HUB power. */
Otavio Salvador801fa152013-03-02 05:17:29 +000042 gpio_direction_output(MX23_PAD_GPMI_ALE__GPIO_0_17, 1);
Marek Vasut3f302a72014-04-28 03:38:42 +020043 udelay(100);
44 return 0;
45}
Otavio Salvador801fa152013-03-02 05:17:29 +000046
Marek Vasut3f302a72014-04-28 03:38:42 +020047int board_ehci_hcd_exit(int port)
48{
49 /* Enable LAN9512 (Maxi) or GL850G (Mini) USB HUB power. */
50 gpio_direction_output(MX23_PAD_GPMI_ALE__GPIO_0_17, 0);
Marek Vasut189e35b2013-01-12 07:11:11 +000051 return 0;
52}
Marek Vasut3f302a72014-04-28 03:38:42 +020053#endif
Marek Vasut189e35b2013-01-12 07:11:11 +000054
55int dram_init(void)
56{
57 return mxs_dram_init();
58}
Marek Vasut73f2b032013-01-22 15:01:05 +000059
Marek Vasut189e35b2013-01-12 07:11:11 +000060int board_init(void)
61{
62 /* Adress of boot parameters */
63 gd->bd->bi_boot_params = PHYS_SDRAM_1 + 0x100;
64
Uri Mashiach4892d392017-01-19 10:51:45 +020065#if defined(CONFIG_LED_STATUS) && defined(CONFIG_LED_STATUS_BOOT_ENABLE)
66 status_led_set(CONFIG_LED_STATUS_BOOT, CONFIG_LED_STATUS_STATE);
Otavio Salvadorfcc76892013-02-23 02:43:09 +000067#endif
68
Marek Vasut189e35b2013-01-12 07:11:11 +000069 return 0;
70}