Re: [PATCH v1 1/2] ARM: boards: protonic-imx6: add board specific BBU SD handlers

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Mar 21, 2022 at 10:21:02AM +0100, Oleksij Rempel wrote:
> Add barebox update handler for the SD ports.
> 
> Signed-off-by: Oleksij Rempel <o.rempel@xxxxxxxxxxxxxx>
> ---
>  arch/arm/boards/protonic-imx6/board.c | 34 +++++++++++++++++++++++++++
>  1 file changed, 34 insertions(+)

Applied, thanks

Sascha

> 
> diff --git a/arch/arm/boards/protonic-imx6/board.c b/arch/arm/boards/protonic-imx6/board.c
> index adde1be8d9..5ca80bd306 100644
> --- a/arch/arm/boards/protonic-imx6/board.c
> +++ b/arch/arm/boards/protonic-imx6/board.c
> @@ -74,6 +74,7 @@ struct prt_machine_data {
>  	unsigned int i2c_addr;
>  	unsigned int i2c_adapter;
>  	unsigned int emmc_usdhc;
> +	unsigned int sd_usdhc;
>  	unsigned int flags;
>  	int (*init)(struct prt_imx6_priv *priv);
>  };
> @@ -442,6 +443,16 @@ static int prt_imx6_bbu(struct prt_imx6_priv *priv)
>  	if (ret)
>  		goto exit_bbu;
>  
> +	devicefile = basprintf("mmc%d", dcfg->sd_usdhc);
> +	if (!devicefile) {
> +		ret = -ENOMEM;
> +		goto exit_bbu;
> +	}
> +
> +	ret = imx6_bbu_internal_mmc_register_handler("SD", devicefile, 0);
> +	if (ret)
> +		goto exit_bbu;
> +
>  	return 0;
>  exit_bbu:
>  	dev_err(priv->dev, "Failed to register bbu: %pe\n", ERR_PTR(ret));
> @@ -850,6 +861,7 @@ static const struct prt_machine_data prt_imx6_cfg_alti6p[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_EMMC,
>  	}, {
>  		.hw_id = UINT_MAX
> @@ -863,6 +875,7 @@ static const struct prt_machine_data prt_imx6_cfg_victgo[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.init = prt_imx6_init_victgo,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
> @@ -877,6 +890,7 @@ static const struct prt_machine_data prt_imx6_cfg_vicut1[] = {
>  		.i2c_addr = 0x50,
>  		.i2c_adapter = 1,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
>  		.hw_id = HW_TYPE_VICUT1,
> @@ -884,6 +898,7 @@ static const struct prt_machine_data prt_imx6_cfg_vicut1[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.init = prt_imx6_init_kvg_yaco,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
> @@ -892,6 +907,7 @@ static const struct prt_machine_data prt_imx6_cfg_vicut1[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.init = prt_imx6_init_kvg_new,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
> @@ -906,6 +922,7 @@ static const struct prt_machine_data prt_imx6_cfg_vicut1q[] = {
>  		.i2c_addr = 0x50,
>  		.i2c_adapter = 1,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
>  		.hw_id = HW_TYPE_VICUT1,
> @@ -913,6 +930,7 @@ static const struct prt_machine_data prt_imx6_cfg_vicut1q[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.init = prt_imx6_init_kvg_yaco,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
> @@ -921,6 +939,7 @@ static const struct prt_machine_data prt_imx6_cfg_vicut1q[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.init = prt_imx6_init_kvg_yaco,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
> @@ -929,6 +948,7 @@ static const struct prt_machine_data prt_imx6_cfg_vicut1q[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.init = prt_imx6_init_kvg_new,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
> @@ -943,6 +963,7 @@ static const struct prt_machine_data prt_imx6_cfg_vicutp[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.init = prt_imx6_init_kvg_new,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
> @@ -957,6 +978,7 @@ static const struct prt_machine_data prt_imx6_cfg_lanmcu[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_EMMC | PRT_IMX6_BOOTCHOOSER,
>  	}, {
>  		.hw_id = UINT_MAX
> @@ -970,6 +992,7 @@ static const struct prt_machine_data prt_imx6_cfg_plybas[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR | PRT_IMX6_USB_LONG_DELAY,
>  	}, {
>  		.hw_id = UINT_MAX
> @@ -983,6 +1006,7 @@ static const struct prt_machine_data prt_imx6_cfg_plym2m[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR | PRT_IMX6_USB_LONG_DELAY,
>  	}, {
>  		.hw_id = UINT_MAX
> @@ -996,6 +1020,7 @@ static const struct prt_machine_data prt_imx6_cfg_prti6g[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 1,
> +		.sd_usdhc = 0,
>  		.init = prt_imx6_init_prti6g,
>  		.flags = PRT_IMX6_BOOTSRC_EMMC | PRT_IMX6_BOOTCHOOSER,
>  	}, {
> @@ -1010,6 +1035,7 @@ static const struct prt_machine_data prt_imx6_cfg_prti6q[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 2,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
>  		.hw_id = HW_TYPE_PRTI6Q,
> @@ -1017,6 +1043,7 @@ static const struct prt_machine_data prt_imx6_cfg_prti6q[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
>  		.hw_id = UINT_MAX
> @@ -1030,6 +1057,7 @@ static const struct prt_machine_data prt_imx6_cfg_prtmvt[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
>  		.hw_id = UINT_MAX
> @@ -1043,6 +1071,7 @@ static const struct prt_machine_data prt_imx6_cfg_prtrvt[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_SPI_NOR,
>  	}, {
>  		.hw_id = UINT_MAX
> @@ -1056,6 +1085,7 @@ static const struct prt_machine_data prt_imx6_cfg_prtvt7[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.init = prt_imx6_init_prtvt7,
>  		.flags = PRT_IMX6_BOOTSRC_EMMC | PRT_IMX6_BOOTCHOOSER |
>  			PRT_IMX6_USB_LONG_DELAY,
> @@ -1071,6 +1101,7 @@ static const struct prt_machine_data prt_imx6_cfg_prtwd2[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_EMMC,
>  	}, {
>  		.hw_id = UINT_MAX
> @@ -1084,6 +1115,7 @@ static const struct prt_machine_data prt_imx6_cfg_prtwd3[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 2,
> +		.sd_usdhc = 0,
>  		.flags = PRT_IMX6_BOOTSRC_EMMC,
>  	}, {
>  		.hw_id = UINT_MAX
> @@ -1097,6 +1129,7 @@ static const struct prt_machine_data prt_imx6_cfg_jozacp[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 0,
> +		.sd_usdhc = 2,
>  		.flags = PRT_IMX6_BOOTSRC_EMMC | PRT_IMX6_BOOTCHOOSER,
>  	}, {
>  		.hw_id = HW_TYPE_JOZACPP,
> @@ -1104,6 +1137,7 @@ static const struct prt_machine_data prt_imx6_cfg_jozacp[] = {
>  		.i2c_addr = 0x51,
>  		.i2c_adapter = 0,
>  		.emmc_usdhc = 0,
> +		.sd_usdhc = 2,
>  		.flags = PRT_IMX6_BOOTSRC_EMMC | PRT_IMX6_BOOTCHOOSER,
>  	}, {
>  		.hw_id = UINT_MAX
> -- 
> 2.30.2
> 
> 
> _______________________________________________
> barebox mailing list
> barebox@xxxxxxxxxxxxxxxxxxx
> http://lists.infradead.org/mailman/listinfo/barebox
> 

-- 
Pengutronix e.K.                           |                             |
Steuerwalder Str. 21                       | http://www.pengutronix.de/  |
31137 Hildesheim, Germany                  | Phone: +49-5121-206917-0    |
Amtsgericht Hildesheim, HRA 2686           | Fax:   +49-5121-206917-5555 |

_______________________________________________
barebox mailing list
barebox@xxxxxxxxxxxxxxxxxxx
http://lists.infradead.org/mailman/listinfo/barebox



[Index of Archives]     [Linux Embedded]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux