mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-16 10:06:44 +07:00
94afd069d9
Currently unsigned ints are used to represent instructions on powerpc. This has worked well as instructions have always been 4 byte words. However, ISA v3.1 introduces some changes to instructions that mean this scheme will no longer work as well. This change is Prefixed Instructions. A prefixed instruction is made up of a word prefix followed by a word suffix to make an 8 byte double word instruction. No matter the endianness of the system the prefix always comes first. Prefixed instructions are only planned for powerpc64. Introduce a ppc_inst type to represent both prefixed and word instructions on powerpc64 while keeping it possible to exclusively have word instructions on powerpc32. Signed-off-by: Jordan Niethe <jniethe5@gmail.com> [mpe: Fix compile error in emulate_spe()] Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/20200506034050.24806-12-jniethe5@gmail.com
15 lines
346 B
C
15 lines
346 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef XMON_BPTS_H
|
|
#define XMON_BPTS_H
|
|
|
|
#define NBPTS 256
|
|
#ifndef __ASSEMBLY__
|
|
#include <asm/inst.h>
|
|
#define BPT_SIZE (sizeof(struct ppc_inst) * 2)
|
|
#define BPT_WORDS (BPT_SIZE / sizeof(struct ppc_inst))
|
|
|
|
extern unsigned int bpt_table[NBPTS * BPT_WORDS];
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
#endif /* XMON_BPTS_H */
|