iTop4412 uboot-2019.2移植之內(nèi)存控制器(七)

一、說明

內(nèi)存控制器非常難配置撮奏,故而不能出錯(cuò)俏讹。我嚴(yán)格按照文檔上的步驟配置,其中的參數(shù)自行體會(huì)畜吊。

二泽疆、配置流程

首先配置內(nèi)存交錯(cuò),然后初始化每個(gè)DMC玲献。

223 void mem_ctrl_init(int reset)
224 {
225     struct exynos4_dmc *dmc1 = (struct exynos4_dmc *)samsung_get_base_dmc_ctrl();
226     struct exynos4_dmc *dmc2 = (struct exynos4_dmc *)(samsung_get_base_dmc_ctrl() + DMC_OFFSET);
227     /**
228     |* 配置內(nèi)存交錯(cuò)
229     |*/
230     writel(APB_SFR_INTERLEAVE_CONF_VAL, &dmc1->ivcontrol);
231     writel(APB_SFR_INTERLEAVE_CONF_VAL, &dmc2->ivcontrol);
232
233     /*
234     |* 初始化內(nèi)存控制器
235     |*/
236     dmc_init(dmc1);
237     dmc_init(dmc2);
238 }

配置步驟在代碼中殉疼,對(duì)比手冊(cè)閱讀

static void dmc_init(struct exynos4_dmc *dmc)
{
    /**
     * Setup 2:
     *  enable PhyControl1.term_write_en, PhyControl1.term_read_en
     */
    writel(mem.control1, &dmc->phycontrol1); //有差異

    /**
     * Stup 3:
     *  disable PhyZQControl.ctrl_zq_mode_noterm
     *  enable PhyZQControl.ctrl_zq_start
     */
    writel(mem.zqcontrol, &dmc->phyzqcontrol);


    /**
     * Setup 4:
     *  set PhyControl0.ctrl_start_point, PhyControl0.ctrl_inc
     *  set PhyControl0.ctrl_dll_on to 1 ——activate PHY DLL
     */
    phy_control_reset(0, dmc);

    /**
     * Setup 5:
     *  set PhyControl1.ctr_shiftc, PhyControl1.ctrl_offsetc
     */
    writel(mem.control1, &dmc->phycontrol1);

    /**
     * Setup 6:
     *  set PhyControl0.ctrl_start to 1
     */
    writel((mem.control0 | CTRL_START | CTRL_DLL_ON), &dmc->phycontrol0);


    /**
     * Setup 7:
     *  set ConControl, close auto refresh
     */
    writel(mem.concontrol, &dmc->concontrol);


    /**
     * Setup 8:
     *  set MemControl, close power down modes, close pzq_en
     */
    writel(mem.memcontrol, &dmc->memcontrol); //差異

    /**
     * Setup 9:
     *  set Memory info
     */
    writel(mem.memconfig0, &dmc->memconfig0);
    writel(mem.memconfig1, &dmc->memconfig1);

    /**
     * Setup 10:
     *  set PrechConfig
     */
    writel(mem.prechconfig, &dmc->prechconfig);

    /**
     * Setup 11:
     *  set TimingAref, TimingRow, TimingData and TimingPower
     */
    writel(mem.timingref, &dmc->timingref);
    writel(mem.timingrow, &dmc->timingrow);
    writel(mem.timingdata, &dmc->timingdata);
    writel(mem.timingpower, &dmc->timingpower);

    /**
     * Setup 13:
     *  wait PhyStatus0.ctrl_clock and PhyStatus0.ctrl_flock to 1
     */

    while(!(dmc->phystatus & 2));

    /**
     * Setup 15,16:
     *  set PhyContron1.fp_resync to 1
     */
    phy_control_reset(1, dmc);

    /**
     * Setup 19:
     *  NOP command
     *  hold CKE to logic high level
     *  chip 0
     */
    writel(DIRECT_CMD_NOP, &dmc->directcmd);

    /**
     * Setup 21:
     *  send EMRS2 command
     *  send EMRS3 command
     *  send EMRS command
     *  send MRS command
     *  chip 0
     */
    dmc_config_mrs(dmc, 0);

    /**
     *Setup 26:
     send ZQINIT command
     chip 0
     */
    writel(DIRECT_CMD_ZQ, &dmc->directcmd);

    /**
     * Setup 19:
     *  NOP command
     *  hold CKE to logic high level
     *  chip 1
     */
    writel((DIRECT_CMD_NOP | DIRECT_CMD_CHIP1_SHIFT), &dmc->directcmd);

    /**
     * Setup 21:
     *  send EMRS2 command
     *  send EMRS3 command
     *  send EMRS command
     *  send MRS command
     *  chip 1
     */
    dmc_config_mrs(dmc, 1);

    /**
     *Setup 26:
     send ZQINIT command
     chip 1
     */
    writel((DIRECT_CMD_ZQ | DIRECT_CMD_CHIP1_SHIFT), &dmc->directcmd);

    /**
     * Setup 28:
     *  set ConControl auto refresh
     */
    writel((mem.concontrol | AREF_EN), &dmc->concontrol);

    /**
     * Setup 29:
     *  set MemControl
     */
    writel((mem.memcontrol | MEMCONTROL_OR), &dmc->memcontrol);
}

三、配置參數(shù)

/********************************************************************************
 *
 * 內(nèi)存控制器的配置
 *
 ********************************************************************************/

/* DMC */
#define DIRECT_CMD_CHIP1_SHIFT  (1 << 20)
#define MEM_TIMINGS_MSR_COUNT   4
#define CTRL_START  (1 << 0)
#define CTRL_DLL_ON (1 << 1)
#define AREF_EN     (1 << 5)
#define DRV_TYPE    (1 << 6)

struct mem_timings {
    unsigned direct_cmd_msr[MEM_TIMINGS_MSR_COUNT];
    unsigned timingref;
    unsigned timingrow;
    unsigned timingdata;
    unsigned timingpower;
    unsigned zqcontrol;
    unsigned control0;
    unsigned control1;
    unsigned control2;
    unsigned concontrol;
    unsigned prechconfig;
    unsigned memcontrol;
    unsigned memconfig0;
    unsigned memconfig1;
    unsigned dll_resync;
    unsigned dll_on;
};

/* MIU */
/* MIU Config Register Offsets*/

#ifdef CONFIG_ITOP4412
#define APB_SFR_INTERLEAVE_CONF_VAL     0x80000007
#endif

#ifdef CONFIG_MIU_1BIT_INTERLEAVED
#define APB_SFR_INTERLEAVE_CONF_VAL 0x0000000c
#endif

#ifdef CONFIG_MIU_2BIT_INTERLEAVED
#define APB_SFR_INTERLEAVE_CONF_VAL 0x2000150c
#endif


#define FORCE_DLL_RESYNC    3
#define DLL_CONTROL_ON      1

#define DIRECT_CMD_NOP  0x07000000
#define DIRECT_CMD1     0x00020000
#define DIRECT_CMD2     0x00030000
#define DIRECT_CMD3     0x00010002
#define DIRECT_CMD4     0x00000328
#define DIRECT_CMD_ZQ   0x0a000000

#define CTRL_ZQ_MODE_NOTERM (0x1 << 0)
#define CTRL_ZQ_START       (0x1 << 1)
#define CTRL_ZQ_DIV         (0x0 << 4)
#define CTRL_ZQ_MODE_DDS    (0x7 << 8)
#define CTRL_ZQ_MODE_TERM   (0x2 << 11)
#define CTRL_ZQ_FORCE_IMPN  (0x5 << 14)
#define CTRL_ZQ_FORCE_IMPP  (0x6 << 17)
#define CTRL_DCC            (0xE38 << 20)
#define ZQ_CONTROL_VAL      (CTRL_ZQ_MODE_NOTERM | CTRL_ZQ_START\
        | CTRL_ZQ_DIV | CTRL_ZQ_MODE_DDS\
        | CTRL_ZQ_MODE_TERM | CTRL_ZQ_FORCE_IMPN\
        | CTRL_ZQ_FORCE_IMPP | CTRL_DCC)

#define ASYNC               (0 << 0)
#define CLK_RATIO           (1 << 1)
#define DIV_PIPE            (1 << 3)
#define AWR_ON              (1 << 4)
#define AREF_DISABLE        (0 << 5)
#define DRV_TYPE_DISABLE    (0 << 6)
#define CHIP0_NOT_EMPTY     (0 << 8)
#define CHIP1_NOT_EMPTY     (0 << 9)
#define DQ_SWAP_DISABLE     (0 << 10)
#define QOS_FAST_DISABLE    (0 << 11)
#define RD_FETCH            (0x3 << 12)
#define TIMEOUT_LEVEL0      (0xFFF << 16)
#define CONCONTROL_VAL      (ASYNC | CLK_RATIO | DIV_PIPE | AWR_ON\
        | AREF_DISABLE | DRV_TYPE_DISABLE\
        | CHIP0_NOT_EMPTY | CHIP1_NOT_EMPTY\
        | DQ_SWAP_DISABLE | QOS_FAST_DISABLE\
        | RD_FETCH | TIMEOUT_LEVEL0)

#define MEMCONTROL_OR       (1 | 2 | (1 << 4) | (1 << 24))
#define CLK_STOP_DISABLE    (0 << 1)
#define DPWRDN_DISABLE      (0 << 2)
#define DPWRDN_TYPE         (0 << 3)
#define TP_DISABLE          (0 << 4)
#define DSREF_DIABLE        (0 << 5)
#define ADD_LAT_PALL        (1 << 6)
#define MEM_TYPE_DDR3       (6 << 8)
#define MEM_WIDTH_32        (2 << 12)
#define NUM_CHIP_2          (1 << 16)
#define BL_8                (3 << 20)
#define MEMCONTROL_VAL      (CLK_STOP_DISABLE | DPWRDN_DISABLE\
        | DPWRDN_TYPE | TP_DISABLE | DSREF_DIABLE\
        | ADD_LAT_PALL | MEM_TYPE_DDR3 | MEM_WIDTH_32\
        | NUM_CHIP_2 | BL_8)


#define CHIP_BANK_8             (0x3 << 0)
#define CHIP_COL_10             (0x3 << 8)
#define CHIP_MAP_INTERLEAVED    (0x1 << 12)

#ifdef CONFIG_MIU_LINEAR
#define CHIP_ROW                (0x2 << 4)
#define CHIP0_BASE              (0x40 << 24)
#define CHIP1_BASE              (0x60 << 24)
#define CHIP_MASK               (0xe0 << 16)
#else
#define CHIP_ROW                (0x3 << 4)
#define CHIP0_BASE              (0x40 << 24)
#define CHIP1_BASE              (0x80 << 24)
#define CHIP_MASK               (0x80 << 16)
#endif

#define MEMCONFIG0_VAL      (CHIP_BANK_8 | CHIP_ROW | CHIP_COL_10\
        | CHIP_MAP_INTERLEAVED | CHIP_MASK | CHIP0_BASE)
#define MEMCONFIG1_VAL      (CHIP_BANK_8 | CHIP_ROW | CHIP_COL_10\
        | CHIP_MAP_INTERLEAVED | CHIP_MASK | CHIP1_BASE)

#define TP_CNT              (0x64 << 24)
#define PRECHCONFIG         TP_CNT

#define CTRL_OFF            (0 << 0)
#define CTRL_DLL_OFF        (0 << 1)
#define CTRL_HALF           (0 << 2)
#define CTRL_DFDQS          (1 << 3)
#define DQS_DELAY           (0 << 4)
#define CTRL_START_POINT    (0x10 << 8)
#define CTRL_INC            (0x10 << 16)
#define CTRL_FORCE          (0x71 << 24)
#define CONTROL0_VAL        (CTRL_OFF | CTRL_DLL_OFF | CTRL_HALF\
        | CTRL_DFDQS | DQS_DELAY | CTRL_START_POINT\
        | CTRL_INC | CTRL_FORCE)

#define CTRL_SHIFTC         (6 << 0)
#define CTRL_REF            (8 << 4)
#define CTRL_SHGATE         (1 << 29)
#define TERM_READ_EN        (1 << 30)
#define TERM_WRITE_EN       (1 << 31)
#define CONTROL1_VAL        (CTRL_SHIFTC | CTRL_REF | CTRL_SHGATE\
        | TERM_READ_EN | TERM_WRITE_EN)

#define CONTROL2_VAL        0x00000000

#ifdef DRAM_CLK_200
#define TIMINGREF_VAL       0x000000BB
#define TIMINGROW_VAL       0x4046654f
#define TIMINGDATA_VAL      0x46400506
#define TIMINGPOWER_VAL     0x52000A3C
#endif

#ifdef DRAM_CLK_330
#define TIMINGREF_VAL       0x000000BC
#define TIMINGROW_VAL       0x3545548d
#define TIMINGDATA_VAL      0x45430506
#define TIMINGPOWER_VAL     0x4439033c
#endif

#ifdef DRAM_CLK_400
#define TIMINGREF_VAL       0x000000BC
#define TIMINGROW_VAL       0x45430506
#define TIMINGDATA_VAL      0x56500506
#define TIMINGPOWER_VAL     0x5444033d
#endif

#endif

修改include/configs/itop4412.h捌年,選擇合適的時(shí)鐘#define CONFIG_CLK_1000_200_200

四瓢娜、驗(yàn)證結(jié)果

讀寫驗(yàn)證:在對(duì)應(yīng)的內(nèi)存區(qū)域隨機(jī)選擇內(nèi)存地址,直接讀寫礼预,看能否正常讀寫眠砾。

內(nèi)存映射:在地址0x40000000處寫入數(shù)據(jù),在0x80000000讀取數(shù)據(jù)托酸,看其值是否一樣褒颈。

內(nèi)存間歇:在0x80000000附近讀寫內(nèi)存柒巫,看內(nèi)存是否連續(xù)。

內(nèi)存長度:在0xC0000000附近讀寫內(nèi)存谷丸,看內(nèi)存實(shí)際容量堡掏。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市刨疼,隨后出現(xiàn)的幾起案子泉唁,更是在濱河造成了極大的恐慌,老刑警劉巖揩慕,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件亭畜,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡漩绵,警方通過查閱死者的電腦和手機(jī)贱案,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來止吐,“玉大人宝踪,你說我怎么就攤上這事“樱” “怎么了瘩燥?”我有些...
    開封第一講書人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長不同。 經(jīng)常有香客問我厉膀,道長,這世上最難降的妖魔是什么二拐? 我笑而不...
    開封第一講書人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任服鹅,我火速辦了婚禮,結(jié)果婚禮上百新,老公的妹妹穿的比我還像新娘企软。我一直安慰自己,他們只是感情好饭望,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開白布仗哨。 她就那樣靜靜地躺著,像睡著了一般铅辞。 火紅的嫁衣襯著肌膚如雪厌漂。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,784評(píng)論 1 290
  • 那天斟珊,我揣著相機(jī)與錄音苇倡,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛雏节,可吹牛的內(nèi)容都是我干的胜嗓。 我是一名探鬼主播,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼钩乍,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了怔锌?” 一聲冷哼從身側(cè)響起寥粹,我...
    開封第一講書人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎埃元,沒想到半個(gè)月后涝涤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡岛杀,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年阔拳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片类嗤。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡糊肠,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出遗锣,到底是詐尸還是另有隱情货裹,我是刑警寧澤,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布精偿,位于F島的核電站弧圆,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏笔咽。R本人自食惡果不足惜搔预,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望叶组。 院中可真熱鬧拯田,春花似錦、人聲如沸扶叉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽枣氧。三九已至溢十,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間达吞,已是汗流浹背张弛。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人吞鸭。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓寺董,卻偏偏與公主長得像,于是被迫代替她去往敵國和親刻剥。 傳聞我的和親對(duì)象是個(gè)殘疾皇子遮咖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • feisky云計(jì)算、虛擬化與Linux技術(shù)筆記posts - 1014, comments - 298, trac...
    不排版閱讀 3,827評(píng)論 0 5
  • 國家電網(wǎng)公司企業(yè)標(biāo)準(zhǔn)(Q/GDW)- 面向?qū)ο蟮挠秒娦畔?shù)據(jù)交換協(xié)議 - 報(bào)批稿:20170802 前言: 排版 ...
    庭說閱讀 10,925評(píng)論 6 13
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,092評(píng)論 1 32
  • 這是一個(gè)充滿選擇的世界造虏,人們每時(shí)每刻都在做著選擇御吞,小如每天的吃穿用度,大到讀大學(xué)漓藕、找工作陶珠、尋找人生方向、確定人生目...
    抓瞎的貓閱讀 222評(píng)論 0 0
  • 恩佐…恩佐… 之前看過《忠犬八公的故事》享钞,后來又看了《拯救雪碧》揍诽。 最近看了《一條狗的使命》,現(xiàn)在看這本書栗竖。很神奇...
    小小棠梨閱讀 1,046評(píng)論 0 0