From mboxrd@z Thu Jan 1 00:00:00 1970 From: Chee, Tien Fong Date: Fri, 9 Dec 2016 10:04:30 +0000 Subject: [U-Boot] [PATCH 06/10] arm: socfpga: arria10: Added drivers for Arria10 Reset Manager In-Reply-To: <01a4cb89-49ce-1bba-80e1-2a09812aeee2@denx.de> References: <1481011707-3639-1-git-send-email-tien.fong.chee@intel.com> <1481111927.2741.32.camel@intel.com> <01a4cb89-49ce-1bba-80e1-2a09812aeee2@denx.de> Message-ID: <1481277869.2741.49.camel@intel.com> List-Id: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: u-boot@lists.denx.de On Rab, 2016-12-07 at 14:58 +0100, Marek Vasut wrote: > On 12/07/2016 12:58 PM, Chee, Tien Fong wrote: > > > > On Sel, 2016-12-06 at 13:55 +0100, Marek Vasut wrote: > > > > > > On 12/06/2016 09:08 AM, Chee Tien Fong wrote: > > > > > > > > > > > > From: Tien Fong Chee > > > > > > > > Drivers for reset manager is restructured such that common > > > > functions, > > > > gen5 drivers and Arria10 drivers are moved to reset_manager.c, > > > > reset_manager_gen5.c and reset_manager_arria10.c respectively. > > > > > > > > Signed-off-by: Tien Fong Chee > > > > Cc: Marek Vasut > > > > Cc: Dinh Nguyen > > > > Cc: Chin Liang See > > > > Cc: Tien Fong > [...] > > > > > > > > > > > > > > +void reset_deassert_dedicated_peripherals(void) > > > > +{ > > > > + int i; > > > > + u32 mask0 = 0; > > > > + u32 mask1 = 0; > > > > + u32 pinmux_addr = SOCFPGA_PINMUX_DEDICATED_IO_ADDRESS; > > > > + u32 mask = 0; > > > > +#if defined(CONFIG_MMC) > > > > + mask |= ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK; > > > > +#elif defined(CONFIG_CADENCE_QSPI) > > > > + mask |= ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK; > > > > +#elif defined(CONFIG_NAND_DENALI) > > > > + mask |= ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK; > > > > +#else > > > Shouldn't this come from OF instead of being ifdef'd ? > > > > > What is OF? > Device Tree (Open Firmware). > > > > > what is your suggestion to make this function generic for > > all type of flash? > Pull it from OF ? > Why you prefer device tree implementation over #define in defconfig, because there is performance penalty. > > > > > > > > > > > > > +#error "unsupported dedicated peripherals" > > > > +#endif > > > > + mask |= ALT_RSTMGR_PER0MODRST_DMAECC_SET_MSK; > > > > + > > > > + /* enable ECC OCP first */ > > > > + clrbits_le32(&reset_manager_base->per0modrst, mask); > > > [...] >