mips: Set the CP0.Config3.DSP and CP0.Config3.DSP2P bits
Set the CP0.Config3.DSP2P bit for the 74kf processor and both that bit and the CP0.Config3.DSP bit for the artificial mips32r5-generic and mips64dspr2 processors. They have the DSPr2 ASE enabled in `insn_flags' and CPUs that implement that ASE need to have both CP0.Config3.DSP and CP0.Config3.DSP2P set or software won't detect its presence. Signed-off-by: Maciej W. Rozycki <macro@codesourcery.com> Reviewed-by: Leon Alrae <leon.alrae@imgtec.com> [leon.alrae@imgtec.com: remove DSP flags from mips32r5-generic] Signed-off-by: Leon Alrae <leon.alrae@imgtec.com>
This commit is contained in:
parent
70409e6726
commit
e30614d517
@ -333,7 +333,8 @@ static const mips_def_t mips_defs[] =
|
|||||||
(0 << CP0C1_DS) | (3 << CP0C1_DL) | (1 << CP0C1_DA) |
|
(0 << CP0C1_DS) | (3 << CP0C1_DL) | (1 << CP0C1_DA) |
|
||||||
(1 << CP0C1_CA),
|
(1 << CP0C1_CA),
|
||||||
.CP0_Config2 = MIPS_CONFIG2,
|
.CP0_Config2 = MIPS_CONFIG2,
|
||||||
.CP0_Config3 = MIPS_CONFIG3 | (0 << CP0C3_VInt) | (1 << CP0C3_DSPP),
|
.CP0_Config3 = MIPS_CONFIG3 | (1 << CP0C3_DSP2P) | (1 << CP0C3_DSPP) |
|
||||||
|
(0 << CP0C3_VInt),
|
||||||
.CP0_LLAddr_rw_bitmask = 0,
|
.CP0_LLAddr_rw_bitmask = 0,
|
||||||
.CP0_LLAddr_shift = 4,
|
.CP0_LLAddr_shift = 4,
|
||||||
.SYNCI_Step = 32,
|
.SYNCI_Step = 32,
|
||||||
@ -376,7 +377,7 @@ static const mips_def_t mips_defs[] =
|
|||||||
(0x93 << FCR0_PRID),
|
(0x93 << FCR0_PRID),
|
||||||
.SEGBITS = 32,
|
.SEGBITS = 32,
|
||||||
.PABITS = 32,
|
.PABITS = 32,
|
||||||
.insn_flags = CPU_MIPS32R5 | ASE_MIPS16 | ASE_DSP | ASE_DSPR2 | ASE_MSA,
|
.insn_flags = CPU_MIPS32R5 | ASE_MIPS16 | ASE_MSA,
|
||||||
.mmu_type = MMU_TYPE_R4000,
|
.mmu_type = MMU_TYPE_R4000,
|
||||||
},
|
},
|
||||||
#if defined(TARGET_MIPS64)
|
#if defined(TARGET_MIPS64)
|
||||||
@ -601,7 +602,8 @@ static const mips_def_t mips_defs[] =
|
|||||||
(2 << CP0C1_DS) | (4 << CP0C1_DL) | (3 << CP0C1_DA) |
|
(2 << CP0C1_DS) | (4 << CP0C1_DL) | (3 << CP0C1_DA) |
|
||||||
(1 << CP0C1_PC) | (1 << CP0C1_WR) | (1 << CP0C1_EP),
|
(1 << CP0C1_PC) | (1 << CP0C1_WR) | (1 << CP0C1_EP),
|
||||||
.CP0_Config2 = MIPS_CONFIG2,
|
.CP0_Config2 = MIPS_CONFIG2,
|
||||||
.CP0_Config3 = MIPS_CONFIG3 | (1 << CP0C3_LPA),
|
.CP0_Config3 = MIPS_CONFIG3 | (1U << CP0C3_M) | (1 << CP0C3_DSP2P) |
|
||||||
|
(1 << CP0C3_DSPP) | (1 << CP0C3_LPA),
|
||||||
.CP0_LLAddr_rw_bitmask = 0,
|
.CP0_LLAddr_rw_bitmask = 0,
|
||||||
.CP0_LLAddr_shift = 0,
|
.CP0_LLAddr_shift = 0,
|
||||||
.SYNCI_Step = 32,
|
.SYNCI_Step = 32,
|
||||||
|
Loading…
Reference in New Issue
Block a user