Commit 0dcfed14 authored by Jean-Christophe PLAGNIOL-VILLARD's avatar Jean-Christophe PLAGNIOL-VILLARD Committed by Nicolas Ferre
Browse files

ARM: at91/pm_slowclock: rename register to named define



This patch will give a name to ARM registers in the assembly
source code. It is done to simplify the code reading and
the passing of parameters to functions.

Signed-off-by: default avatarJean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
Acked-by: default avatarNicolas Ferre <nicolas.ferre@atmel.com>
parent 9e1c0b2e
Loading
Loading
Loading
Loading
+91 −86
Original line number Original line Diff line number Diff line
@@ -46,17 +46,22 @@
#define PLLALOCK_TIMEOUT	1000
#define PLLALOCK_TIMEOUT	1000
#define PLLBLOCK_TIMEOUT	1000
#define PLLBLOCK_TIMEOUT	1000


pmc	.req	r1
sdramc	.req	r2
tmp1	.req	r3
tmp2	.req	r4
ramc1	.req	r5


/*
/*
 * Wait until master clock is ready (after switching master clock source)
 * Wait until master clock is ready (after switching master clock source)
 */
 */
	.macro wait_mckrdy
	.macro wait_mckrdy
	mov	r4, #MCKRDY_TIMEOUT
	mov	tmp2, #MCKRDY_TIMEOUT
1:	sub	r4, r4, #1
1:	sub	tmp2, tmp2, #1
	cmp	r4, #0
	cmp	tmp2, #0
	beq	2f
	beq	2f
	ldr	r3, [r1, #(AT91_PMC_SR - AT91_PMC)]
	ldr	tmp1, [pmc, #(AT91_PMC_SR - AT91_PMC)]
	tst	r3, #AT91_PMC_MCKRDY
	tst	tmp1, #AT91_PMC_MCKRDY
	beq	1b
	beq	1b
2:
2:
	.endm
	.endm
@@ -65,12 +70,12 @@
 * Wait until master oscillator has stabilized.
 * Wait until master oscillator has stabilized.
 */
 */
	.macro wait_moscrdy
	.macro wait_moscrdy
	mov	r4, #MOSCRDY_TIMEOUT
	mov	tmp2, #MOSCRDY_TIMEOUT
1:	sub	r4, r4, #1
1:	sub	tmp2, tmp2, #1
	cmp	r4, #0
	cmp	tmp2, #0
	beq	2f
	beq	2f
	ldr	r3, [r1, #(AT91_PMC_SR - AT91_PMC)]
	ldr	tmp1, [pmc, #(AT91_PMC_SR - AT91_PMC)]
	tst	r3, #AT91_PMC_MOSCS
	tst	tmp1, #AT91_PMC_MOSCS
	beq	1b
	beq	1b
2:
2:
	.endm
	.endm
@@ -79,12 +84,12 @@
 * Wait until PLLA has locked.
 * Wait until PLLA has locked.
 */
 */
	.macro wait_pllalock
	.macro wait_pllalock
	mov	r4, #PLLALOCK_TIMEOUT
	mov	tmp2, #PLLALOCK_TIMEOUT
1:	sub	r4, r4, #1
1:	sub	tmp2, tmp2, #1
	cmp	r4, #0
	cmp	tmp2, #0
	beq	2f
	beq	2f
	ldr	r3, [r1, #(AT91_PMC_SR - AT91_PMC)]
	ldr	tmp1, [pmc, #(AT91_PMC_SR - AT91_PMC)]
	tst	r3, #AT91_PMC_LOCKA
	tst	tmp1, #AT91_PMC_LOCKA
	beq	1b
	beq	1b
2:
2:
	.endm
	.endm
@@ -93,12 +98,12 @@
 * Wait until PLLB has locked.
 * Wait until PLLB has locked.
 */
 */
	.macro wait_pllblock
	.macro wait_pllblock
	mov	r4, #PLLBLOCK_TIMEOUT
	mov	tmp2, #PLLBLOCK_TIMEOUT
1:	sub	r4, r4, #1
1:	sub	tmp2, tmp2, #1
	cmp	r4, #0
	cmp	tmp2, #0
	beq	2f
	beq	2f
	ldr	r3, [r1, #(AT91_PMC_SR - AT91_PMC)]
	ldr	tmp1, [pmc, #(AT91_PMC_SR - AT91_PMC)]
	tst	r3, #AT91_PMC_LOCKB
	tst	tmp1, #AT91_PMC_LOCKB
	beq	1b
	beq	1b
2:
2:
	.endm
	.endm
@@ -117,55 +122,55 @@ ENTRY(at91_slow_clock)
	 *  R4 = temporary register
	 *  R4 = temporary register
	 *  R5 = Base address of second RAM Controller or 0 if not present
	 *  R5 = Base address of second RAM Controller or 0 if not present
	 */
	 */
	ldr	r1, .at91_va_base_pmc
	ldr	pmc, .at91_va_base_pmc
	ldr	r2, .at91_va_base_sdramc
	ldr	sdramc, .at91_va_base_sdramc
	ldr	r5, .at91_va_base_ramc1
	ldr	ramc1, .at91_va_base_ramc1


	/* Drain write buffer */
	/* Drain write buffer */
	mov	r0, #0
	mov	tmp1, #0
	mcr	p15, 0, r0, c7, c10, 4
	mcr	p15, 0, tmp1, c7, c10, 4


#ifdef CONFIG_ARCH_AT91RM9200
#ifdef CONFIG_ARCH_AT91RM9200
	/* Put SDRAM in self-refresh mode */
	/* Put SDRAM in self-refresh mode */
	mov	r3, #1
	mov	tmp1, #1
	str	r3, [r2, #AT91_SDRAMC_SRR]
	str	tmp1, [sdramc, #AT91_SDRAMC_SRR]
#elif defined(CONFIG_ARCH_AT91SAM9G45)
#elif defined(CONFIG_ARCH_AT91SAM9G45)


	/* prepare for DDRAM self-refresh mode */
	/* prepare for DDRAM self-refresh mode */
	ldr	r3, [r2, #AT91_DDRSDRC_LPR]
	ldr	tmp1, [sdramc, #AT91_DDRSDRC_LPR]
	str	r3, .saved_sam9_lpr
	str	tmp1, .saved_sam9_lpr
	bic	r3, #AT91_DDRSDRC_LPCB
	bic	tmp1, #AT91_DDRSDRC_LPCB
	orr	r3, #AT91_DDRSDRC_LPCB_SELF_REFRESH
	orr	tmp1, #AT91_DDRSDRC_LPCB_SELF_REFRESH


	/* figure out if we use the second ram controller */
	/* figure out if we use the second ram controller */
	cmp	r5, #0
	cmp	ramc1, #0
	ldrne	r4, [r5, #AT91_DDRSDRC_LPR]
	ldrne	tmp2, [ramc1, #AT91_DDRSDRC_LPR]
	strne	r4, .saved_sam9_lpr1
	strne	tmp2, .saved_sam9_lpr1
	bicne	r4, #AT91_DDRSDRC_LPCB
	bicne	tmp2, #AT91_DDRSDRC_LPCB
	orrne	r4, #AT91_DDRSDRC_LPCB_SELF_REFRESH
	orrne	tmp2, #AT91_DDRSDRC_LPCB_SELF_REFRESH


	/* Enable DDRAM self-refresh mode */
	/* Enable DDRAM self-refresh mode */
	str	r3, [r2, #AT91_DDRSDRC_LPR]
	str	tmp1, [sdramc, #AT91_DDRSDRC_LPR]
	strne	r4, [r5, #AT91_DDRSDRC_LPR]
	strne	tmp2, [ramc1, #AT91_DDRSDRC_LPR]
#else
#else
	/* Enable SDRAM self-refresh mode */
	/* Enable SDRAM self-refresh mode */
	ldr	r3, [r2, #AT91_SDRAMC_LPR]
	ldr	tmp1, [sdramc, #AT91_SDRAMC_LPR]
	str	r3, .saved_sam9_lpr
	str	tmp1, .saved_sam9_lpr


	bic	r3, #AT91_SDRAMC_LPCB
	bic	tmp1, #AT91_SDRAMC_LPCB
	orr	r3, #AT91_SDRAMC_LPCB_SELF_REFRESH
	orr	tmp1, #AT91_SDRAMC_LPCB_SELF_REFRESH
	str	r3, [r2, #AT91_SDRAMC_LPR]
	str	tmp1, [sdramc, #AT91_SDRAMC_LPR]
#endif
#endif


	/* Save Master clock setting */
	/* Save Master clock setting */
	ldr	r3, [r1, #(AT91_PMC_MCKR - AT91_PMC)]
	ldr	tmp1, [pmc, #(AT91_PMC_MCKR - AT91_PMC)]
	str	r3, .saved_mckr
	str	tmp1, .saved_mckr


	/*
	/*
	 * Set the Master clock source to slow clock
	 * Set the Master clock source to slow clock
	 */
	 */
	bic	r3, r3, #AT91_PMC_CSS
	bic	tmp1, tmp1, #AT91_PMC_CSS
	str	r3, [r1, #(AT91_PMC_MCKR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_PMC_MCKR - AT91_PMC)]


	wait_mckrdy
	wait_mckrdy


@@ -175,61 +180,61 @@ ENTRY(at91_slow_clock)
	 *
	 *
	 * See AT91RM9200 errata #27 and #28 for details.
	 * See AT91RM9200 errata #27 and #28 for details.
	 */
	 */
	mov	r3, #0
	mov	tmp1, #0
	str	r3, [r1, #(AT91_PMC_MCKR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_PMC_MCKR - AT91_PMC)]


	wait_mckrdy
	wait_mckrdy
#endif
#endif


	/* Save PLLA setting and disable it */
	/* Save PLLA setting and disable it */
	ldr	r3, [r1, #(AT91_CKGR_PLLAR - AT91_PMC)]
	ldr	tmp1, [pmc, #(AT91_CKGR_PLLAR - AT91_PMC)]
	str	r3, .saved_pllar
	str	tmp1, .saved_pllar


	mov	r3, #AT91_PMC_PLLCOUNT
	mov	tmp1, #AT91_PMC_PLLCOUNT
	orr	r3, r3, #(1 << 29)		/* bit 29 always set */
	orr	tmp1, tmp1, #(1 << 29)		/* bit 29 always set */
	str	r3, [r1, #(AT91_CKGR_PLLAR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_CKGR_PLLAR - AT91_PMC)]


	/* Save PLLB setting and disable it */
	/* Save PLLB setting and disable it */
	ldr	r3, [r1, #(AT91_CKGR_PLLBR - AT91_PMC)]
	ldr	tmp1, [pmc, #(AT91_CKGR_PLLBR - AT91_PMC)]
	str	r3, .saved_pllbr
	str	tmp1, .saved_pllbr


	mov	r3, #AT91_PMC_PLLCOUNT
	mov	tmp1, #AT91_PMC_PLLCOUNT
	str	r3, [r1, #(AT91_CKGR_PLLBR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_CKGR_PLLBR - AT91_PMC)]


	/* Turn off the main oscillator */
	/* Turn off the main oscillator */
	ldr	r3, [r1, #(AT91_CKGR_MOR - AT91_PMC)]
	ldr	tmp1, [pmc, #(AT91_CKGR_MOR - AT91_PMC)]
	bic	r3, r3, #AT91_PMC_MOSCEN
	bic	tmp1, tmp1, #AT91_PMC_MOSCEN
	str	r3, [r1, #(AT91_CKGR_MOR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_CKGR_MOR - AT91_PMC)]


	/* Wait for interrupt */
	/* Wait for interrupt */
	mcr	p15, 0, r0, c7, c0, 4
	mcr	p15, 0, tmp1, c7, c0, 4


	/* Turn on the main oscillator */
	/* Turn on the main oscillator */
	ldr	r3, [r1, #(AT91_CKGR_MOR - AT91_PMC)]
	ldr	tmp1, [pmc, #(AT91_CKGR_MOR - AT91_PMC)]
	orr	r3, r3, #AT91_PMC_MOSCEN
	orr	tmp1, tmp1, #AT91_PMC_MOSCEN
	str	r3, [r1, #(AT91_CKGR_MOR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_CKGR_MOR - AT91_PMC)]


	wait_moscrdy
	wait_moscrdy


	/* Restore PLLB setting */
	/* Restore PLLB setting */
	ldr	r3, .saved_pllbr
	ldr	tmp1, .saved_pllbr
	str	r3, [r1, #(AT91_CKGR_PLLBR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_CKGR_PLLBR - AT91_PMC)]


	tst	r3, #(AT91_PMC_MUL &  0xff0000)
	tst	tmp1, #(AT91_PMC_MUL &  0xff0000)
	bne	1f
	bne	1f
	tst	r3, #(AT91_PMC_MUL & ~0xff0000)
	tst	tmp1, #(AT91_PMC_MUL & ~0xff0000)
	beq	2f
	beq	2f
1:
1:
	wait_pllblock
	wait_pllblock
2:
2:


	/* Restore PLLA setting */
	/* Restore PLLA setting */
	ldr	r3, .saved_pllar
	ldr	tmp1, .saved_pllar
	str	r3, [r1, #(AT91_CKGR_PLLAR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_CKGR_PLLAR - AT91_PMC)]


	tst	r3, #(AT91_PMC_MUL &  0xff0000)
	tst	tmp1, #(AT91_PMC_MUL &  0xff0000)
	bne	3f
	bne	3f
	tst	r3, #(AT91_PMC_MUL & ~0xff0000)
	tst	tmp1, #(AT91_PMC_MUL & ~0xff0000)
	beq	4f
	beq	4f
3:
3:
	wait_pllalock
	wait_pllalock
@@ -242,11 +247,11 @@ ENTRY(at91_slow_clock)
	 *
	 *
	 * See AT91RM9200 errata #27 and #28 for details.
	 * See AT91RM9200 errata #27 and #28 for details.
	 */
	 */
	ldr	r3, .saved_mckr
	ldr	tmp1, .saved_mckr
	tst	r3, #AT91_PMC_PRES
	tst	tmp1, #AT91_PMC_PRES
	beq	2f
	beq	2f
	and	r3, r3, #AT91_PMC_PRES
	and	tmp1, tmp1, #AT91_PMC_PRES
	str	r3, [r1, #(AT91_PMC_MCKR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_PMC_MCKR - AT91_PMC)]


	wait_mckrdy
	wait_mckrdy
#endif
#endif
@@ -254,8 +259,8 @@ ENTRY(at91_slow_clock)
	/*
	/*
	 * Restore master clock setting
	 * Restore master clock setting
	 */
	 */
2:	ldr	r3, .saved_mckr
2:	ldr	tmp1, .saved_mckr
	str	r3, [r1, #(AT91_PMC_MCKR - AT91_PMC)]
	str	tmp1, [pmc, #(AT91_PMC_MCKR - AT91_PMC)]


	wait_mckrdy
	wait_mckrdy


@@ -263,18 +268,18 @@ ENTRY(at91_slow_clock)
	/* Do nothing - self-refresh is automatically disabled. */
	/* Do nothing - self-refresh is automatically disabled. */
#elif defined(CONFIG_ARCH_AT91SAM9G45)
#elif defined(CONFIG_ARCH_AT91SAM9G45)
	/* Restore LPR on AT91 with DDRAM */
	/* Restore LPR on AT91 with DDRAM */
	ldr	r3, .saved_sam9_lpr
	ldr	tmp1, .saved_sam9_lpr
	str	r3, [r2, #AT91_DDRSDRC_LPR]
	str	tmp1, [sdramc, #AT91_DDRSDRC_LPR]


	/* if we use the second ram controller */
	/* if we use the second ram controller */
	cmp	r5, #0
	cmp	ramc1, #0
	ldrne	r4, .saved_sam9_lpr1
	ldrne	tmp2, .saved_sam9_lpr1
	strne	r4, [r5, #AT91_DDRSDRC_LPR]
	strne	tmp2, [ramc1, #AT91_DDRSDRC_LPR]


#else
#else
	/* Restore LPR on AT91 with SDRAM */
	/* Restore LPR on AT91 with SDRAM */
	ldr	r3, .saved_sam9_lpr
	ldr	tmp1, .saved_sam9_lpr
	str	r3, [r2, #AT91_SDRAMC_LPR]
	str	tmp1, [sdramc, #AT91_SDRAMC_LPR]
#endif
#endif


	/* Restore registers, and return */
	/* Restore registers, and return */