commit
1fdafb2e3d
@ -0,0 +1,115 @@ |
||||
/* |
||||
* Copyright 2013 CompuLab Ltd. |
||||
* |
||||
* Author: Valentin Raevsky <valentin@compulab.co.il> |
||||
* |
||||
* The code contained herein is licensed under the GNU General Public |
||||
* License. You may obtain a copy of the GNU General Public License |
||||
* Version 2 or later at the following locations: |
||||
* |
||||
* http://www.opensource.org/licenses/gpl-license.html |
||||
* http://www.gnu.org/copyleft/gpl.html |
||||
*/ |
||||
|
||||
/dts-v1/; |
||||
#include "imx6q.dtsi" |
||||
|
||||
/ { |
||||
model = "CompuLab CM-FX6"; |
||||
compatible = "compulab,cm-fx6", "fsl,imx6q"; |
||||
|
||||
memory { |
||||
reg = <0x10000000 0x80000000>; |
||||
}; |
||||
|
||||
leds { |
||||
compatible = "gpio-leds"; |
||||
|
||||
heartbeat-led { |
||||
label = "Heartbeat"; |
||||
gpios = <&gpio2 31 0>; |
||||
linux,default-trigger = "heartbeat"; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&fec { |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&pinctrl_enet>; |
||||
phy-mode = "rgmii"; |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&gpmi { |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&pinctrl_gpmi_nand>; |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&iomuxc { |
||||
imx6q-cm-fx6 { |
||||
pinctrl_enet: enetgrp { |
||||
fsl,pins = < |
||||
MX6QDL_PAD_RGMII_RXC__RGMII_RXC 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_RD0__RGMII_RD0 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_RD1__RGMII_RD1 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_RD2__RGMII_RD2 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_RD3__RGMII_RD3 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_TXC__RGMII_TXC 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_TD0__RGMII_TD0 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_TD1__RGMII_TD1 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_TD2__RGMII_TD2 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_TD3__RGMII_TD3 0x1b0b0 |
||||
MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL 0x1b0b0 |
||||
MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK 0x1b0b0 |
||||
MX6QDL_PAD_ENET_MDIO__ENET_MDIO 0x1b0b0 |
||||
MX6QDL_PAD_ENET_MDC__ENET_MDC 0x1b0b0 |
||||
MX6QDL_PAD_GPIO_16__ENET_REF_CLK 0x4001b0a8 |
||||
>; |
||||
}; |
||||
|
||||
pinctrl_gpmi_nand: gpminandgrp { |
||||
fsl,pins = < |
||||
MX6QDL_PAD_NANDF_CLE__NAND_CLE 0xb0b1 |
||||
MX6QDL_PAD_NANDF_ALE__NAND_ALE 0xb0b1 |
||||
MX6QDL_PAD_NANDF_WP_B__NAND_WP_B 0xb0b1 |
||||
MX6QDL_PAD_NANDF_RB0__NAND_READY_B 0xb000 |
||||
MX6QDL_PAD_NANDF_CS0__NAND_CE0_B 0xb0b1 |
||||
MX6QDL_PAD_NANDF_CS1__NAND_CE1_B 0xb0b1 |
||||
MX6QDL_PAD_SD4_CMD__NAND_RE_B 0xb0b1 |
||||
MX6QDL_PAD_SD4_CLK__NAND_WE_B 0xb0b1 |
||||
MX6QDL_PAD_NANDF_D0__NAND_DATA00 0xb0b1 |
||||
MX6QDL_PAD_NANDF_D1__NAND_DATA01 0xb0b1 |
||||
MX6QDL_PAD_NANDF_D2__NAND_DATA02 0xb0b1 |
||||
MX6QDL_PAD_NANDF_D3__NAND_DATA03 0xb0b1 |
||||
MX6QDL_PAD_NANDF_D4__NAND_DATA04 0xb0b1 |
||||
MX6QDL_PAD_NANDF_D5__NAND_DATA05 0xb0b1 |
||||
MX6QDL_PAD_NANDF_D6__NAND_DATA06 0xb0b1 |
||||
MX6QDL_PAD_NANDF_D7__NAND_DATA07 0xb0b1 |
||||
MX6QDL_PAD_SD4_DAT0__NAND_DQS 0x00b1 |
||||
>; |
||||
}; |
||||
|
||||
pinctrl_uart4: uart4grp { |
||||
fsl,pins = < |
||||
MX6QDL_PAD_KEY_COL0__UART4_TX_DATA 0x1b0b1 |
||||
MX6QDL_PAD_KEY_ROW0__UART4_RX_DATA 0x1b0b1 |
||||
>; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&uart4 { |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&pinctrl_uart4>; |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&sata { |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&usdhc3 { |
||||
status = "okay"; |
||||
}; |
@ -0,0 +1,104 @@ |
||||
/*
|
||||
* Handling of common block commands |
||||
* |
||||
* Copyright (c) 2017 Google, Inc |
||||
* |
||||
* (C) Copyright 2000-2011 |
||||
* Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ |
||||
*/ |
||||
|
||||
#include <common.h> |
||||
#include <blk.h> |
||||
|
||||
#ifdef HAVE_BLOCK_DEVICE |
||||
int blk_common_cmd(int argc, char * const argv[], enum if_type if_type, |
||||
int *cur_devnump) |
||||
{ |
||||
const char *if_name = blk_get_if_type_name(if_type); |
||||
|
||||
switch (argc) { |
||||
case 0: |
||||
case 1: |
||||
return CMD_RET_USAGE; |
||||
case 2: |
||||
if (strncmp(argv[1], "inf", 3) == 0) { |
||||
blk_list_devices(if_type); |
||||
return 0; |
||||
} else if (strncmp(argv[1], "dev", 3) == 0) { |
||||
if (blk_print_device_num(if_type, *cur_devnump)) { |
||||
printf("\nno %s devices available\n", if_name); |
||||
return CMD_RET_FAILURE; |
||||
} |
||||
return 0; |
||||
} else if (strncmp(argv[1], "part", 4) == 0) { |
||||
if (blk_list_part(if_type)) |
||||
printf("\nno %s devices available\n", if_name); |
||||
return 0; |
||||
} |
||||
return CMD_RET_USAGE; |
||||
case 3: |
||||
if (strncmp(argv[1], "dev", 3) == 0) { |
||||
int dev = (int)simple_strtoul(argv[2], NULL, 10); |
||||
|
||||
if (!blk_show_device(if_type, dev)) { |
||||
*cur_devnump = dev; |
||||
printf("... is now current device\n"); |
||||
} else { |
||||
return CMD_RET_FAILURE; |
||||
} |
||||
return 0; |
||||
} else if (strncmp(argv[1], "part", 4) == 0) { |
||||
int dev = (int)simple_strtoul(argv[2], NULL, 10); |
||||
|
||||
if (blk_print_part_devnum(if_type, dev)) { |
||||
printf("\n%s device %d not available\n", |
||||
if_name, dev); |
||||
return CMD_RET_FAILURE; |
||||
} |
||||
return 0; |
||||
} |
||||
return CMD_RET_USAGE; |
||||
|
||||
default: /* at least 4 args */ |
||||
if (strcmp(argv[1], "read") == 0) { |
||||
ulong addr = simple_strtoul(argv[2], NULL, 16); |
||||
lbaint_t blk = simple_strtoul(argv[3], NULL, 16); |
||||
ulong cnt = simple_strtoul(argv[4], NULL, 16); |
||||
ulong n; |
||||
|
||||
printf("\n%s read: device %d block # %lld, count %ld ... ", |
||||
if_name, *cur_devnump, (unsigned long long)blk, |
||||
cnt); |
||||
|
||||
n = blk_read_devnum(if_type, *cur_devnump, blk, cnt, |
||||
(ulong *)addr); |
||||
|
||||
printf("%ld blocks read: %s\n", n, |
||||
n == cnt ? "OK" : "ERROR"); |
||||
return n == cnt ? 0 : 1; |
||||
} else if (strcmp(argv[1], "write") == 0) { |
||||
ulong addr = simple_strtoul(argv[2], NULL, 16); |
||||
lbaint_t blk = simple_strtoul(argv[3], NULL, 16); |
||||
ulong cnt = simple_strtoul(argv[4], NULL, 16); |
||||
ulong n; |
||||
|
||||
printf("\n%s write: device %d block # %lld, count %ld ... ", |
||||
if_name, *cur_devnump, (unsigned long long)blk, |
||||
cnt); |
||||
|
||||
n = blk_write_devnum(if_type, *cur_devnump, blk, cnt, |
||||
(ulong *)addr); |
||||
|
||||
printf("%ld blocks written: %s\n", n, |
||||
n == cnt ? "OK" : "ERROR"); |
||||
return n == cnt ? 0 : 1; |
||||
} else { |
||||
return CMD_RET_USAGE; |
||||
} |
||||
|
||||
return 0; |
||||
} |
||||
} |
||||
#endif |
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,16 @@ |
||||
/*
|
||||
* Copyright 2017 Google, Inc |
||||
* Written by Simon Glass <sjg@chromium.org> |
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ |
||||
*/ |
||||
|
||||
#ifndef __DWC_AHSATA_H__ |
||||
#define __DWC_AHSATA_H__ |
||||
|
||||
int dwc_ahsata_bus_reset(struct udevice *dev); |
||||
int dwc_ahsata_probe(struct udevice *dev); |
||||
int dwc_ahsata_scan(struct udevice *dev); |
||||
int dwc_ahsata_port_status(struct udevice *dev, int port); |
||||
|
||||
#endif |
Loading…
Reference in new issue