- Aug 08, 2015
-
-
Marek Vasut authored
Actually convert the sequencer code to use socfpga_sdram_rw_mgr_config instead of the RW_MGR_* macros. This is just an sed exercise here, no manual coding needed. Signed-off-by:
Marek Vasut <marex@denx.de> Acked-by:
Dinh Nguyen <dinguyen@opensource.altera.com>
-
Marek Vasut authored
Introduce structure socfpga_sdram_rw_mgr_config to wrap the RW manager configuration values in board file. Introduce a complementary function, socfpga_get_sdram_rwmgr_config(), which returns this the structure. This is another step toward wrapping the nasty QTS generated macros in board files and reducing the pollution of the namespace. Signed-off-by:
Marek Vasut <marex@denx.de> Acked-by:
Dinh Nguyen <dinguyen@opensource.altera.com>
-
Marek Vasut authored
Introduce two wrapper functions, socfpga_get_seq_ac_init() and socfpga_get_seq_inst_init() to avoid direct inclusion of the sequencer_auto_ac_init.h and sequencer_auto_inst_init.h QTS generated files. This reduces namespace pollution again. Signed-off-by:
Marek Vasut <marex@denx.de> Acked-by:
Dinh Nguyen <dinguyen@opensource.altera.com>
-
Marek Vasut authored
This is defined in the QTS-generated headers, so it must not be re-defined in sequencer.h . Signed-off-by:
Marek Vasut <marex@denx.de> Acked-by:
Dinh Nguyen <dinguyen@opensource.altera.com>
-
Marek Vasut authored
These parameters are not used in the code, zap them and the macros which are used by them as well. Signed-off-by:
Marek Vasut <marex@denx.de> Acked-by:
Dinh Nguyen <dinguyen@opensource.altera.com>
-
Marek Vasut authored
Zap non-existent functions and place function prototypes at the beginning of the header file. Signed-off-by:
Marek Vasut <marex@denx.de> Acked-by:
Dinh Nguyen <dinguyen@opensource.altera.com>
-
Marek Vasut authored
Move the files generated by QTS into the board directory, they should not be part of the driver files at all. Signed-off-by:
Marek Vasut <marex@denx.de> Acked-by:
Dinh Nguyen <dinguyen@opensource.altera.com>
-
Marek Vasut authored
Originally, both sdram_start and sdram_end were 64b values. The sdram_start had no reason for being so, since our address space is only 32b, so switching sdram_start to u32 is simple. The sdram_end is a bit more complex, since it can actually be set to (1 << 32) if someone really wanted to use an SoCFPGA with 4 GiB of DRAM and fixed the code around a little. But, the code handling the protection rules internally decrements the sdram_end variable anyway. Thus, instead of calling the code and passing in the address of the SDRAM end, pass in the address already decremented by one. This lets the sdram_end be 32b as well. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Fix the data types and zap unnecessary type change. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Zap an obscure unneeded cast and clean other minor nits in this function. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Add kerneldoc to functions which are missing it, but are already cleaned up. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Clean the function up so that it's obvious what it is doing, fix the formating strings in debug outputs, add kerneldoc. Make the function return proper errno-compliant return values and propagate this change throughout sdram.c Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Clean up coding style, mostly clean up comments, add kerneldoc. Also, zap assignment of the "cs" variable, which is outright dead code, so just remove it. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Pluck out all of the CONFIG_HPS_SDR_CTRLCFG_* macros. This change makes sdram.c completely clear of these macros and allows removing of the ugly include of sdram.h . The namespace is now a much nicer place! Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Introduce socfpga_sdram_get_config() function implement in a board file, which returns the socfpga_sdram_config structure. This is the last step in cleaning up the socfpga_mmr_init_full(), but not the last step which allows removing the inclusion of sdram.h from drivers/ddr/altera/sdram.c thus far. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Fix the return value so that standard errno return values can be used. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Add kerneldoc. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Pull out the block of register programming into a separate function. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Rework remaining two register setting functions such that they only return the final register value. Move the register setting into the block of register I/O in sdram_mmr_init_full(). Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Merge sdr_set_*() functions which are just setting registers among the sea of register setting in sdram_mmr_init_full(). There is no need to keep them separate this way, there is nothing special about them. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Pluck out the remaining CONFIG_HPS_SDR_CTRLCFG_ and put it into the socfpga_sdram_config structure. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Suck out all the CONFIG_HPS_SDR_CTRLCFG_* from sdram_mmr_init_full() into the socfpga_sdram_config structure. There is still one ugly macro left behind, but this will be taken care of in subsequent patch. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Zap all the ad-hoc readbacks from the registers and other useless and broken debug output. This is really not useful and is only confusing. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Introduce this seemingly massive structure, which holds required values of all the registers of the SDRAM controller. The idea here is to avoid including the sdram.h header file, which is full of ad-hoc macros that polute the global namespace. Once the cleanup of sdram.c would be complete and all registers would be loaded from this new socfpga_sdram_config, a board file will only pass this structure into the sdram.c . This will hide all the horrors generated by QTS in the board directory. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Get rid of the constant clrsetbits_le32(), instead prepare the whole content of the register once and write it at the end of the function. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Get rid of the constant clrsetbits_le32(), instead prepare the whole content of the register once and write it at the end of the function. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Get rid of the constant clrsetbits_le32(), instead prepare the whole content of the register once and write it at the end of the function. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Get rid of the constant clrsetbits_le32(), instead prepare the whole content of the register once and write it at the end of the function. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Get rid of the constant clrsetbits_le32(), instead prepare the whole content of the register once and write it at the end of the function. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Get rid of the constant clrsetbits_le32(), instead prepare the whole content of the register once and write it at the end of the function. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Get rid of the constant clrsetbits_le32(), instead prepare the whole content of the register once and write it at the end of the function. Merge set_sdr_dram_timing{1,2,3,4,lowpwr}() into single function set_sdr_dram_timing() , since there's no point in keeping all this stuff separate anymore. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Get rid of the constant clrsetbits_le32(), instead prepare the whole content of the register once and write it at the end of the function. The big plan here is to remove all the CONFIG_HPS_SDR_ macros, hide them in QTS compatibility layer in board implementation and pass only a small structure into the driver. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Remove all parameters of this function, since they are only constants passed in from another function, so make them local. Also, rename the function to get_errata_rows() as this is closer to what it does. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Clean up weird parenthesis and odd type casts from the function. Fix comment style. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Use generic function instead of CPU-specific one. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Add a small workaround into the platform code which forces the SDMMC into 8-bit mode (the default configuration for all socfpga platforms) to work around breakage caused by missing patches in mainline which switch the probing of SD/MMC to OF instead of static configuraiton. The patches will hit mainline after the SPL series, so to avoid build issues, add this small temporary workaround. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Add kerneldoc. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Simplify the loop code, optimizing compiler can deal with this. No functional change. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Clean up the computation of c_loop, outer and inner variables. Signed-off-by:
Marek Vasut <marex@denx.de>
-
Marek Vasut authored
Factor out (afi_clocks - 1) into a single place instead of having it all around the function. Signed-off-by:
Marek Vasut <marex@denx.de>
-