[U-Boot] [PATCH 1/2] armv8: emc2305: add support for fan controller

Meenakshi Aggarwal meenakshi.aggarwal at nxp.com
Tue Feb 5 06:37:52 UTC 2019


Gentle reminter

> -----Original Message-----
> From: Meenakshi Aggarwal <meenakshi.aggarwal at nxp.com>
> Sent: Friday, November 30, 2018 10:32 PM
> To: u-boot at lists.denx.de; York Sun <york.sun at nxp.com>
> Cc: Meenakshi Aggarwal <meenakshi.aggarwal at nxp.com>
> Subject: [PATCH 1/2] armv8: emc2305: add support for fan controller
> 
> Add support for fan controller emc2305.
> 
> Signed-off-by: Sriram Dash <sriram.dash at nxp.com>
> Signed-off-by: Meenakshi Aggarwal <meenakshi.aggarwal at nxp.com>
> ---
>  arch/arm/cpu/armv8/fsl-layerscape/Kconfig |  6 +++++
>  board/freescale/common/Makefile           |  2 ++
>  board/freescale/common/emc2305.c          | 41
> +++++++++++++++++++++++++++++++
>  board/freescale/common/emc2305.h          | 23 +++++++++++++++++
>  4 files changed, 72 insertions(+)
>  create mode 100644 board/freescale/common/emc2305.c  create mode
> 100644 board/freescale/common/emc2305.h
> 
> diff --git a/arch/arm/cpu/armv8/fsl-layerscape/Kconfig
> b/arch/arm/cpu/armv8/fsl-layerscape/Kconfig
> index 5dba2af..b0e779d 100644
> --- a/arch/arm/cpu/armv8/fsl-layerscape/Kconfig
> +++ b/arch/arm/cpu/armv8/fsl-layerscape/Kconfig
> @@ -346,6 +346,12 @@ config MAX_CPUS
>  	  cores, count the reserved ports. This will allocate enough memory
>  	  in spin table to properly handle all cores.
> 
> +config EMC2305
> +	bool "Fan controller"
> +	help
> +	 Enable the EMC2305 fan controller for configuration of fan
> +	 speed.
> +
>  config SECURE_BOOT
>  	bool "Secure Boot"
>  	help
> diff --git a/board/freescale/common/Makefile
> b/board/freescale/common/Makefile index e3c5eae..a9d61a8 100644
> --- a/board/freescale/common/Makefile
> +++ b/board/freescale/common/Makefile
> @@ -64,6 +64,8 @@ obj-$(CONFIG_POWER_MC34VR500)	+=
> mc34vr500.o
> 
>  obj-$(CONFIG_LS102XA_STREAM_ID)	+= ls102xa_stream_id.o
> 
> +obj-$(CONFIG_EMC2305)              += emc2305.o
> +
>  # deal with common files for P-series corenet based devices
>  obj-$(CONFIG_TARGET_P2041RDB)	+= p_corenet/
>  obj-$(CONFIG_TARGET_P3041DS)	+= p_corenet/
> diff --git a/board/freescale/common/emc2305.c
> b/board/freescale/common/emc2305.c
> new file mode 100644
> index 0000000..8523084
> --- /dev/null
> +++ b/board/freescale/common/emc2305.c
> @@ -0,0 +1,41 @@
> +// SPDX-License-Identifier: GPL-2.0+
> +/*
> + * Copyright 2018 NXP.
> + *
> + * SPDX-License-Identifier:     GPL-2.0+
> + */
> +
> +#include <common.h>
> +#include <command.h>
> +#include <i2c.h>
> +#include <asm/io.h>
> +
> +#include "emc2305.h"
> +
> +DECLARE_GLOBAL_DATA_PTR;
> +
> +void set_fan_speed(u8 data)
> +{
> +	u8 index;
> +	u8 Fan[NUM_OF_FANS] = {I2C_EMC2305_FAN1,
> +			       I2C_EMC2305_FAN2,
> +			       I2C_EMC2305_FAN3,
> +			       I2C_EMC2305_FAN4,
> +			       I2C_EMC2305_FAN5};
> +
> +	for (index = 0; index < NUM_OF_FANS; index++) {
> +		if (i2c_write(I2C_EMC2305_ADDR, Fan[index], 1, &data, 1) != 0)
> {
> +			printf("Error: failed to change fan speed @%x\n",
> +			       Fan[index]);
> +		}
> +	}
> +}
> +
> +void emc2305_init(void)
> +{
> +	u8 data;
> +
> +	data = I2C_EMC2305_CMD;
> +	if (i2c_write(I2C_EMC2305_ADDR, I2C_EMC2305_CONF, 1, &data, 1) !=
> 0)
> +		printf("Error: failed to configure EMC2305\n"); }
> diff --git a/board/freescale/common/emc2305.h
> b/board/freescale/common/emc2305.h
> new file mode 100644
> index 0000000..eddf537
> --- /dev/null
> +++ b/board/freescale/common/emc2305.h
> @@ -0,0 +1,23 @@
> +/* SPDX-License-Identifier: GPL-2.0+ */
> +/*
> + * Copyright 2018 NXP
> + *
> + * SPDX-License-Identifier:     GPL-2.0+
> + */
> +
> +#ifndef __EMC2305_H_
> +#define __EMC2305_H_
> +
> +#define I2C_EMC2305_CONF		0x20
> +#define I2C_EMC2305_FAN1		0x30
> +#define I2C_EMC2305_FAN2		0x40
> +#define I2C_EMC2305_FAN3		0x50
> +#define I2C_EMC2305_FAN4		0x60
> +#define I2C_EMC2305_FAN5		0x70
> +
> +#define NUM_OF_FANS			5
> +
> +void emc2305_init(void);
> +void set_fan_speed(u8 data);
> +
> +#endif  /* __EMC2305_H_ */
> --
> 1.9.1



More information about the U-Boot mailing list