Commit 6aec8e05 authored by Jiaxun Yang's avatar Jiaxun Yang Committed by Thomas Bogendoerfer
Browse files

MIPS: page: Use GPR number macros



Use GPR number macros in uasm code generation parts to
reduce code duplication.

No functional change.

Signed-off-by: default avatarJiaxun Yang <jiaxun.yang@flygoat.com>
Signed-off-by: default avatarThomas Bogendoerfer <tsbogend@alpha.franken.de>
parent c2fb9fe4
Loading
Loading
Loading
Loading
+95 −107
Original line number Diff line number Diff line
@@ -24,6 +24,7 @@
#include <asm/bootinfo.h>
#include <asm/mipsregs.h>
#include <asm/mmu_context.h>
#include <asm/regdef.h>
#include <asm/cpu.h>

#ifdef CONFIG_SIBYTE_DMA_PAGEOPS
@@ -34,19 +35,6 @@

#include <asm/uasm.h>

/* Registers used in the assembled routines. */
#define ZERO 0
#define AT 2
#define A0 4
#define A1 5
#define A2 6
#define T0 8
#define T1 9
#define T2 10
#define T3 11
#define T9 25
#define RA 31

/* Handle labels (which must be positive integers). */
enum label_id {
	label_clear_nopref = 1,
@@ -106,16 +94,16 @@ pg_addiu(u32 **buf, unsigned int reg1, unsigned int reg2, unsigned int off)
	    IS_ENABLED(CONFIG_CPU_DADDI_WORKAROUNDS) &&
	    r4k_daddiu_bug()) {
		if (off > 0x7fff) {
			uasm_i_lui(buf, T9, uasm_rel_hi(off));
			uasm_i_addiu(buf, T9, T9, uasm_rel_lo(off));
			uasm_i_lui(buf, GPR_T9, uasm_rel_hi(off));
			uasm_i_addiu(buf, GPR_T9, GPR_T9, uasm_rel_lo(off));
		} else
			uasm_i_addiu(buf, T9, ZERO, off);
		uasm_i_daddu(buf, reg1, reg2, T9);
			uasm_i_addiu(buf, GPR_T9, GPR_ZERO, off);
		uasm_i_daddu(buf, reg1, reg2, GPR_T9);
	} else {
		if (off > 0x7fff) {
			uasm_i_lui(buf, T9, uasm_rel_hi(off));
			uasm_i_addiu(buf, T9, T9, uasm_rel_lo(off));
			UASM_i_ADDU(buf, reg1, reg2, T9);
			uasm_i_lui(buf, GPR_T9, uasm_rel_hi(off));
			uasm_i_addiu(buf, GPR_T9, GPR_T9, uasm_rel_lo(off));
			UASM_i_ADDU(buf, reg1, reg2, GPR_T9);
		} else
			UASM_i_ADDIU(buf, reg1, reg2, off);
	}
@@ -233,9 +221,9 @@ static void set_prefetch_parameters(void)
static void build_clear_store(u32 **buf, int off)
{
	if (cpu_has_64bit_gp_regs || cpu_has_64bit_zero_reg) {
		uasm_i_sd(buf, ZERO, off, A0);
		uasm_i_sd(buf, GPR_ZERO, off, GPR_A0);
	} else {
		uasm_i_sw(buf, ZERO, off, A0);
		uasm_i_sw(buf, GPR_ZERO, off, GPR_A0);
	}
}

@@ -246,10 +234,10 @@ static inline void build_clear_pref(u32 **buf, int off)

	if (pref_bias_clear_store) {
		_uasm_i_pref(buf, pref_dst_mode, pref_bias_clear_store + off,
			    A0);
			    GPR_A0);
	} else if (cache_line_size == (half_clear_loop_size << 1)) {
		if (cpu_has_cache_cdex_s) {
			uasm_i_cache(buf, Create_Dirty_Excl_SD, off, A0);
			uasm_i_cache(buf, Create_Dirty_Excl_SD, off, GPR_A0);
		} else if (cpu_has_cache_cdex_p) {
			if (IS_ENABLED(CONFIG_WAR_R4600_V1_HIT_CACHEOP) &&
			    cpu_is_r4600_v1_x()) {
@@ -261,9 +249,9 @@ static inline void build_clear_pref(u32 **buf, int off)

			if (IS_ENABLED(CONFIG_WAR_R4600_V2_HIT_CACHEOP) &&
			    cpu_is_r4600_v2_x())
				uasm_i_lw(buf, ZERO, ZERO, AT);
				uasm_i_lw(buf, GPR_ZERO, GPR_ZERO, GPR_AT);

			uasm_i_cache(buf, Create_Dirty_Excl_D, off, A0);
			uasm_i_cache(buf, Create_Dirty_Excl_D, off, GPR_A0);
		}
	}
}
@@ -301,12 +289,12 @@ void build_clear_page(void)

	off = PAGE_SIZE - pref_bias_clear_store;
	if (off > 0xffff || !pref_bias_clear_store)
		pg_addiu(&buf, A2, A0, off);
		pg_addiu(&buf, GPR_A2, GPR_A0, off);
	else
		uasm_i_ori(&buf, A2, A0, off);
		uasm_i_ori(&buf, GPR_A2, GPR_A0, off);

	if (IS_ENABLED(CONFIG_WAR_R4600_V2_HIT_CACHEOP) && cpu_is_r4600_v2_x())
		uasm_i_lui(&buf, AT, uasm_rel_hi(0xa0000000));
		uasm_i_lui(&buf, GPR_AT, uasm_rel_hi(0xa0000000));

	off = cache_line_size ? min(8, pref_bias_clear_store / cache_line_size)
				* cache_line_size : 0;
@@ -320,36 +308,36 @@ void build_clear_page(void)
		build_clear_store(&buf, off);
		off += clear_word_size;
	} while (off < half_clear_loop_size);
	pg_addiu(&buf, A0, A0, 2 * off);
	pg_addiu(&buf, GPR_A0, GPR_A0, 2 * off);
	off = -off;
	do {
		build_clear_pref(&buf, off);
		if (off == -clear_word_size)
			uasm_il_bne(&buf, &r, A0, A2, label_clear_pref);
			uasm_il_bne(&buf, &r, GPR_A0, GPR_A2, label_clear_pref);
		build_clear_store(&buf, off);
		off += clear_word_size;
	} while (off < 0);

	if (pref_bias_clear_store) {
		pg_addiu(&buf, A2, A0, pref_bias_clear_store);
		pg_addiu(&buf, GPR_A2, GPR_A0, pref_bias_clear_store);
		uasm_l_clear_nopref(&l, buf);
		off = 0;
		do {
			build_clear_store(&buf, off);
			off += clear_word_size;
		} while (off < half_clear_loop_size);
		pg_addiu(&buf, A0, A0, 2 * off);
		pg_addiu(&buf, GPR_A0, GPR_A0, 2 * off);
		off = -off;
		do {
			if (off == -clear_word_size)
				uasm_il_bne(&buf, &r, A0, A2,
				uasm_il_bne(&buf, &r, GPR_A0, GPR_A2,
					    label_clear_nopref);
			build_clear_store(&buf, off);
			off += clear_word_size;
		} while (off < 0);
	}

	uasm_i_jr(&buf, RA);
	uasm_i_jr(&buf, GPR_RA);
	uasm_i_nop(&buf);

	BUG_ON(buf > &__clear_page_end);
@@ -369,18 +357,18 @@ void build_clear_page(void)
static void build_copy_load(u32 **buf, int reg, int off)
{
	if (cpu_has_64bit_gp_regs) {
		uasm_i_ld(buf, reg, off, A1);
		uasm_i_ld(buf, reg, off, GPR_A1);
	} else {
		uasm_i_lw(buf, reg, off, A1);
		uasm_i_lw(buf, reg, off, GPR_A1);
	}
}

static void build_copy_store(u32 **buf, int reg, int off)
{
	if (cpu_has_64bit_gp_regs) {
		uasm_i_sd(buf, reg, off, A0);
		uasm_i_sd(buf, reg, off, GPR_A0);
	} else {
		uasm_i_sw(buf, reg, off, A0);
		uasm_i_sw(buf, reg, off, GPR_A0);
	}
}

@@ -390,7 +378,7 @@ static inline void build_copy_load_pref(u32 **buf, int off)
		return;

	if (pref_bias_copy_load)
		_uasm_i_pref(buf, pref_src_mode, pref_bias_copy_load + off, A1);
		_uasm_i_pref(buf, pref_src_mode, pref_bias_copy_load + off, GPR_A1);
}

static inline void build_copy_store_pref(u32 **buf, int off)
@@ -400,10 +388,10 @@ static inline void build_copy_store_pref(u32 **buf, int off)

	if (pref_bias_copy_store) {
		_uasm_i_pref(buf, pref_dst_mode, pref_bias_copy_store + off,
			    A0);
			    GPR_A0);
	} else if (cache_line_size == (half_copy_loop_size << 1)) {
		if (cpu_has_cache_cdex_s) {
			uasm_i_cache(buf, Create_Dirty_Excl_SD, off, A0);
			uasm_i_cache(buf, Create_Dirty_Excl_SD, off, GPR_A0);
		} else if (cpu_has_cache_cdex_p) {
			if (IS_ENABLED(CONFIG_WAR_R4600_V1_HIT_CACHEOP) &&
			    cpu_is_r4600_v1_x()) {
@@ -415,9 +403,9 @@ static inline void build_copy_store_pref(u32 **buf, int off)

			if (IS_ENABLED(CONFIG_WAR_R4600_V2_HIT_CACHEOP) &&
			    cpu_is_r4600_v2_x())
				uasm_i_lw(buf, ZERO, ZERO, AT);
				uasm_i_lw(buf, GPR_ZERO, GPR_ZERO, GPR_AT);

			uasm_i_cache(buf, Create_Dirty_Excl_D, off, A0);
			uasm_i_cache(buf, Create_Dirty_Excl_D, off, GPR_A0);
		}
	}
}
@@ -454,12 +442,12 @@ void build_copy_page(void)

	off = PAGE_SIZE - pref_bias_copy_load;
	if (off > 0xffff || !pref_bias_copy_load)
		pg_addiu(&buf, A2, A0, off);
		pg_addiu(&buf, GPR_A2, GPR_A0, off);
	else
		uasm_i_ori(&buf, A2, A0, off);
		uasm_i_ori(&buf, GPR_A2, GPR_A0, off);

	if (IS_ENABLED(CONFIG_WAR_R4600_V2_HIT_CACHEOP) && cpu_is_r4600_v2_x())
		uasm_i_lui(&buf, AT, uasm_rel_hi(0xa0000000));
		uasm_i_lui(&buf, GPR_AT, uasm_rel_hi(0xa0000000));

	off = cache_line_size ? min(8, pref_bias_copy_load / cache_line_size) *
				cache_line_size : 0;
@@ -476,126 +464,126 @@ void build_copy_page(void)
	uasm_l_copy_pref_both(&l, buf);
	do {
		build_copy_load_pref(&buf, off);
		build_copy_load(&buf, T0, off);
		build_copy_load(&buf, GPR_T0, off);
		build_copy_load_pref(&buf, off + copy_word_size);
		build_copy_load(&buf, T1, off + copy_word_size);
		build_copy_load(&buf, GPR_T1, off + copy_word_size);
		build_copy_load_pref(&buf, off + 2 * copy_word_size);
		build_copy_load(&buf, T2, off + 2 * copy_word_size);
		build_copy_load(&buf, GPR_T2, off + 2 * copy_word_size);
		build_copy_load_pref(&buf, off + 3 * copy_word_size);
		build_copy_load(&buf, T3, off + 3 * copy_word_size);
		build_copy_load(&buf, GPR_T3, off + 3 * copy_word_size);
		build_copy_store_pref(&buf, off);
		build_copy_store(&buf, T0, off);
		build_copy_store(&buf, GPR_T0, off);
		build_copy_store_pref(&buf, off + copy_word_size);
		build_copy_store(&buf, T1, off + copy_word_size);
		build_copy_store(&buf, GPR_T1, off + copy_word_size);
		build_copy_store_pref(&buf, off + 2 * copy_word_size);
		build_copy_store(&buf, T2, off + 2 * copy_word_size);
		build_copy_store(&buf, GPR_T2, off + 2 * copy_word_size);
		build_copy_store_pref(&buf, off + 3 * copy_word_size);
		build_copy_store(&buf, T3, off + 3 * copy_word_size);
		build_copy_store(&buf, GPR_T3, off + 3 * copy_word_size);
		off += 4 * copy_word_size;
	} while (off < half_copy_loop_size);
	pg_addiu(&buf, A1, A1, 2 * off);
	pg_addiu(&buf, A0, A0, 2 * off);
	pg_addiu(&buf, GPR_A1, GPR_A1, 2 * off);
	pg_addiu(&buf, GPR_A0, GPR_A0, 2 * off);
	off = -off;
	do {
		build_copy_load_pref(&buf, off);
		build_copy_load(&buf, T0, off);
		build_copy_load(&buf, GPR_T0, off);
		build_copy_load_pref(&buf, off + copy_word_size);
		build_copy_load(&buf, T1, off + copy_word_size);
		build_copy_load(&buf, GPR_T1, off + copy_word_size);
		build_copy_load_pref(&buf, off + 2 * copy_word_size);
		build_copy_load(&buf, T2, off + 2 * copy_word_size);
		build_copy_load(&buf, GPR_T2, off + 2 * copy_word_size);
		build_copy_load_pref(&buf, off + 3 * copy_word_size);
		build_copy_load(&buf, T3, off + 3 * copy_word_size);
		build_copy_load(&buf, GPR_T3, off + 3 * copy_word_size);
		build_copy_store_pref(&buf, off);
		build_copy_store(&buf, T0, off);
		build_copy_store(&buf, GPR_T0, off);
		build_copy_store_pref(&buf, off + copy_word_size);
		build_copy_store(&buf, T1, off + copy_word_size);
		build_copy_store(&buf, GPR_T1, off + copy_word_size);
		build_copy_store_pref(&buf, off + 2 * copy_word_size);
		build_copy_store(&buf, T2, off + 2 * copy_word_size);
		build_copy_store(&buf, GPR_T2, off + 2 * copy_word_size);
		build_copy_store_pref(&buf, off + 3 * copy_word_size);
		if (off == -(4 * copy_word_size))
			uasm_il_bne(&buf, &r, A2, A0, label_copy_pref_both);
		build_copy_store(&buf, T3, off + 3 * copy_word_size);
			uasm_il_bne(&buf, &r, GPR_A2, GPR_A0, label_copy_pref_both);
		build_copy_store(&buf, GPR_T3, off + 3 * copy_word_size);
		off += 4 * copy_word_size;
	} while (off < 0);

	if (pref_bias_copy_load - pref_bias_copy_store) {
		pg_addiu(&buf, A2, A0,
		pg_addiu(&buf, GPR_A2, GPR_A0,
			 pref_bias_copy_load - pref_bias_copy_store);
		uasm_l_copy_pref_store(&l, buf);
		off = 0;
		do {
			build_copy_load(&buf, T0, off);
			build_copy_load(&buf, T1, off + copy_word_size);
			build_copy_load(&buf, T2, off + 2 * copy_word_size);
			build_copy_load(&buf, T3, off + 3 * copy_word_size);
			build_copy_load(&buf, GPR_T0, off);
			build_copy_load(&buf, GPR_T1, off + copy_word_size);
			build_copy_load(&buf, GPR_T2, off + 2 * copy_word_size);
			build_copy_load(&buf, GPR_T3, off + 3 * copy_word_size);
			build_copy_store_pref(&buf, off);
			build_copy_store(&buf, T0, off);
			build_copy_store(&buf, GPR_T0, off);
			build_copy_store_pref(&buf, off + copy_word_size);
			build_copy_store(&buf, T1, off + copy_word_size);
			build_copy_store(&buf, GPR_T1, off + copy_word_size);
			build_copy_store_pref(&buf, off + 2 * copy_word_size);
			build_copy_store(&buf, T2, off + 2 * copy_word_size);
			build_copy_store(&buf, GPR_T2, off + 2 * copy_word_size);
			build_copy_store_pref(&buf, off + 3 * copy_word_size);
			build_copy_store(&buf, T3, off + 3 * copy_word_size);
			build_copy_store(&buf, GPR_T3, off + 3 * copy_word_size);
			off += 4 * copy_word_size;
		} while (off < half_copy_loop_size);
		pg_addiu(&buf, A1, A1, 2 * off);
		pg_addiu(&buf, A0, A0, 2 * off);
		pg_addiu(&buf, GPR_A1, GPR_A1, 2 * off);
		pg_addiu(&buf, GPR_A0, GPR_A0, 2 * off);
		off = -off;
		do {
			build_copy_load(&buf, T0, off);
			build_copy_load(&buf, T1, off + copy_word_size);
			build_copy_load(&buf, T2, off + 2 * copy_word_size);
			build_copy_load(&buf, T3, off + 3 * copy_word_size);
			build_copy_load(&buf, GPR_T0, off);
			build_copy_load(&buf, GPR_T1, off + copy_word_size);
			build_copy_load(&buf, GPR_T2, off + 2 * copy_word_size);
			build_copy_load(&buf, GPR_T3, off + 3 * copy_word_size);
			build_copy_store_pref(&buf, off);
			build_copy_store(&buf, T0, off);
			build_copy_store(&buf, GPR_T0, off);
			build_copy_store_pref(&buf, off + copy_word_size);
			build_copy_store(&buf, T1, off + copy_word_size);
			build_copy_store(&buf, GPR_T1, off + copy_word_size);
			build_copy_store_pref(&buf, off + 2 * copy_word_size);
			build_copy_store(&buf, T2, off + 2 * copy_word_size);
			build_copy_store(&buf, GPR_T2, off + 2 * copy_word_size);
			build_copy_store_pref(&buf, off + 3 * copy_word_size);
			if (off == -(4 * copy_word_size))
				uasm_il_bne(&buf, &r, A2, A0,
				uasm_il_bne(&buf, &r, GPR_A2, GPR_A0,
					    label_copy_pref_store);
			build_copy_store(&buf, T3, off + 3 * copy_word_size);
			build_copy_store(&buf, GPR_T3, off + 3 * copy_word_size);
			off += 4 * copy_word_size;
		} while (off < 0);
	}

	if (pref_bias_copy_store) {
		pg_addiu(&buf, A2, A0, pref_bias_copy_store);
		pg_addiu(&buf, GPR_A2, GPR_A0, pref_bias_copy_store);
		uasm_l_copy_nopref(&l, buf);
		off = 0;
		do {
			build_copy_load(&buf, T0, off);
			build_copy_load(&buf, T1, off + copy_word_size);
			build_copy_load(&buf, T2, off + 2 * copy_word_size);
			build_copy_load(&buf, T3, off + 3 * copy_word_size);
			build_copy_store(&buf, T0, off);
			build_copy_store(&buf, T1, off + copy_word_size);
			build_copy_store(&buf, T2, off + 2 * copy_word_size);
			build_copy_store(&buf, T3, off + 3 * copy_word_size);
			build_copy_load(&buf, GPR_T0, off);
			build_copy_load(&buf, GPR_T1, off + copy_word_size);
			build_copy_load(&buf, GPR_T2, off + 2 * copy_word_size);
			build_copy_load(&buf, GPR_T3, off + 3 * copy_word_size);
			build_copy_store(&buf, GPR_T0, off);
			build_copy_store(&buf, GPR_T1, off + copy_word_size);
			build_copy_store(&buf, GPR_T2, off + 2 * copy_word_size);
			build_copy_store(&buf, GPR_T3, off + 3 * copy_word_size);
			off += 4 * copy_word_size;
		} while (off < half_copy_loop_size);
		pg_addiu(&buf, A1, A1, 2 * off);
		pg_addiu(&buf, A0, A0, 2 * off);
		pg_addiu(&buf, GPR_A1, GPR_A1, 2 * off);
		pg_addiu(&buf, GPR_A0, GPR_A0, 2 * off);
		off = -off;
		do {
			build_copy_load(&buf, T0, off);
			build_copy_load(&buf, T1, off + copy_word_size);
			build_copy_load(&buf, T2, off + 2 * copy_word_size);
			build_copy_load(&buf, T3, off + 3 * copy_word_size);
			build_copy_store(&buf, T0, off);
			build_copy_store(&buf, T1, off + copy_word_size);
			build_copy_store(&buf, T2, off + 2 * copy_word_size);
			build_copy_load(&buf, GPR_T0, off);
			build_copy_load(&buf, GPR_T1, off + copy_word_size);
			build_copy_load(&buf, GPR_T2, off + 2 * copy_word_size);
			build_copy_load(&buf, GPR_T3, off + 3 * copy_word_size);
			build_copy_store(&buf, GPR_T0, off);
			build_copy_store(&buf, GPR_T1, off + copy_word_size);
			build_copy_store(&buf, GPR_T2, off + 2 * copy_word_size);
			if (off == -(4 * copy_word_size))
				uasm_il_bne(&buf, &r, A2, A0,
				uasm_il_bne(&buf, &r, GPR_A2, GPR_A0,
					    label_copy_nopref);
			build_copy_store(&buf, T3, off + 3 * copy_word_size);
			build_copy_store(&buf, GPR_T3, off + 3 * copy_word_size);
			off += 4 * copy_word_size;
		} while (off < 0);
	}

	uasm_i_jr(&buf, RA);
	uasm_i_jr(&buf, GPR_RA);
	uasm_i_nop(&buf);

	BUG_ON(buf > &__copy_page_end);