[PATCH v4 3/9] arm: mach-mvebu: add source files

Gregory CLEMENT gregory.clement at free-electrons.com
Wed Jun 27 03:52:18 EDT 2012


On 06/26/2012 06:17 PM, Arnd Bergmann wrote:
> On Tuesday 26 June 2012, Gregory Clement wrote:
>> From: Gregory CLEMENT <gregory.clement at free-electrons.com>
>>
>> Signed-off-by: Gregory CLEMENT <gregory.clement at free-electrons.com>
>> Signed-off-by: Thomas Petazzoni <thomas.petazzoni at free-electrons.com>
>> Signed-off-by: Lior Amsalem <alior at marvell.com>
> 
> This driver seems to do all the right things now, good work.
> 
>> +static void __iomem *system_controller_base;
>> +static void __iomem *reset_base;
>> +static unsigned long rstoutn_mask_reset_out_en;
>> +
>> +/* System controller registers */
>> +#define ARMADA_370_XP_RESET_OFFSET		  0x60
>> +#define OTHER_MVEBU_RESET_OFFSET		 0x108
>> +#define MVEBU_RSTOUTN_MASK_OFFSET		   0x0
>> +#define   OTHER_MVEBU_RSTOUTN_MASK_RESET_OUT_EN	   0x4
>> +#define   ARMADA_370_XP_RSTOUTN_MASK_RESET_OUT_EN  0x1
>> +#define MVEBU_SYSTEM_SOFT_RESET_OFFSET		   0x4
>> +#define   MVEBU_SYSTEM_SOFT_RESET		   0x1
>> +
>> +#define OTHER_MVEBU_VARIANT	1
>> +#define ARMADA_370_XP_VARIANT	2
> 
> I think this can be expressed nicer with pointers to data structures,
> like
> 
> static void __iomem *system_controller_base;
> 
> struct mvebu_system_controller {
> 	u32 rstoutn_mask_offset;
> 	u32 system_soft_reset_offset;
> 
> 	u32 rstoutn_mask_reset_out_en;
> 	u32 system_soft_reset;
> };
> 
> const struct mvebu_system_controller armada_370_xp_system_controller = {
> 	.rstoutn_mask_offset = 0x60,
> 	.system_soft_reset_offset = 0x64,
> 	.rstoutn_mask_reset_out_en = 0x1,
> 	.system_soft_reset = 0x1,
> };
> 
> const struct mvebu_system_controller orion_system_controller = {
> 	.rstoutn_mask_offset = 0x108,
> 	.system_soft_reset_offset = 0x10c,
> 	.rstoutn_mask_reset_out_en = 0x4,
> 	.system_soft_reset = 0x1,
> };
> 
> static struct of_device_id of_system_controller_table[] = {
> 	{.compatible = "marvell,orion-system-controller",
> 	 .data = &orion,system_controller},
> 	{.compatible = "marvell,armada-370-xp-system-controller",
> 	 .data = &armada_370_xp_system_controller,
> 	{ /* end of list */ },
> };

OK I will make this improvements.

> 
>> +void mvebu_restart(char mode, const char *cmd)
>> +{
>> +	if (!system_controller_base) {
>> +		pr_warn("Cannot restart, system-controller not available\n");
>> +		return;
>> +	}
> 
> I guess returning here is a bug, you should just enter the endless
> loop.

You're right.

> 
> 	Arnd
> 


-- 
Gregory Clement, Free Electrons
Kernel, drivers, real-time and embedded Linux
development, consulting, training and support.
http://free-electrons.com





More information about the linux-arm-kernel mailing list