#pragma ident "%Z%%M% %I% %E% SMI"
#include <sys/cpu_module.h>
#include <vm/page.h>
#include <vm/seg_map.h>
void
cpu_fiximp(pnode_t dnode)
{}
void
ce_err(void)
{}
void
ce_err_tl1(void)
{}
void
async_err(void)
{}
void
cpu_flush_ecache(void)
{}
void
cpu_disable_errors(void)
{}
void
cpu_enable_errors(void)
{}
void
cpu_faulted_enter(struct cpu *cp)
{}
void
cpu_faulted_exit(struct cpu *cp)
{}
void
cpu_ce_count_unum(struct async_flt *ecc, int len, char *unum)
{}
void
cpu_ce_scrub_mem_err(struct async_flt *ecc, boolean_t triedcpulogout)
{}
void
cpu_ce_log_err(struct async_flt *ecc, errorq_elem_t *eqep)
{}
void
cpu_ue_log_err(struct async_flt *ecc)
{}
int
ce_scrub_xdiag_recirc(struct async_flt *aflt, errorq_t *eqp,
errorq_elem_t *eqep, size_t afltoffset)
{ return (0); }
char *
flt_to_error_type(struct async_flt *aflt)
{ return (NULL); }
int
cpu_aflt_size(void)
{ return (0); }
void
cpu_async_panic_callb(void)
{}
void
cpu_check_allcpus(struct async_flt *aflt)
{}
int
cpu_get_mem_sid(char *unum, char *buf, int buflen, int *lenp)
{ return (ENOTSUP); }
int
cpu_get_mem_offset(uint64_t flt_addr, uint64_t *offp)
{ return (ENOTSUP); }
int
cpu_get_mem_addr(char *unum, char *sid, uint64_t offset,
uint64_t *addrp)
{ return (ENOTSUP); }
int
cpu_get_mem_unum(int synd_stat, ushort_t synd, uint64_t afsr, uint64_t afar,
int cpuid, int flt_in_memory, ushort_t flt_status, char *buf,
int buflen, int *lenp)
{ return (ENOTSUP); }
int
cpu_get_mem_unum_aflt(int synd_stat, struct async_flt *aflt,
char *buf, int buflen, int *lenp)
{ return (ENOTSUP); }
int
cpu_get_cpu_unum(int cpuid, char *buf, int buflen, int *lenp)
{ return (ENOTSUP); }
int
cpu_get_mem_name(uint64_t synd, uint64_t *afsr, uint64_t afar,
char *buf, int buflen, int *lenp)
{ return (ENOTSUP); }
size_t
cpu_get_name_bufsize()
{ return (0); }
int
cpu_get_mem_info(uint64_t synd, uint64_t afar,
uint64_t *mem_sizep, uint64_t *seg_sizep, uint64_t *bank_sizep,
int *segsp, int *banksp, int *mcidp)
{ return (ENOTSUP); }
void
cpu_ereport_post(struct async_flt *aflt)
{}
void
cpu_run_bus_error_handlers(struct async_flt *aflt, int expected)
{}
void
cpu_errorq_dispatch(char *error_class, void *payload, size_t payload_sz,
errorq_t *eqp, uint_t flag)
{}
void
clr_datapath(void)
{}
void
read_ecc_data(struct async_flt *ecc, short verbose, short ce_err)
{}
void
itlb_rd_entry(uint_t entry, tte_t *tte, uint64_t *va_tag)
{}
void
dtlb_rd_entry(uint_t entry, tte_t *tte, uint64_t *va_tag)
{}
void
cpu_clearticknpt(void)
{ }
void
cpu_init_cache_scrub(void)
{}
void
cpu_busy_ecache_scrub(struct cpu *cp)
{}
void
cpu_idle_ecache_scrub(struct cpu *cp)
{}
void
cpu_check_ce(int flag, uint64_t pa, caddr_t va, uint_t bpp)
{}
void
prefetch_page_w(void *pp)
{
#define ECACHE_SUBBLOCKS_PER_PAGE 2
#define ECACHE_SUBBLOCK_SIZE_BYTES 64
#define ECACHE_PAGE_BYTE_MAX \
(ECACHE_SUBBLOCKS_PER_PAGE*ECACHE_SUBBLOCK_SIZE_BYTES+1)
volatile int garbage[ECACHE_PAGE_BYTE_MAX - sizeof (page_t)];
}
void
prefetch_page_r(void *pp)
{
#define ECACHE_SUBBLOCKS_PER_PAGE 2
#define ECACHE_SUBBLOCK_SIZE_BYTES 64
#define ECACHE_PAGE_BYTE_MAX \
(ECACHE_SUBBLOCKS_PER_PAGE*ECACHE_SUBBLOCK_SIZE_BYTES+1)
volatile int garbage[ECACHE_PAGE_BYTE_MAX - sizeof (page_t)];
}
#ifdef SEGKPM_SUPPORT
#define SMAP_SIZE 80
#else
#define SMAP_SIZE 56
#endif
void
prefetch_smap_w(void *smp)
{
volatile int smap_size_changed [SMAP_SIZE - sizeof (struct smap) + 1];
volatile int smap_size_changed2 [sizeof (struct smap) - SMAP_SIZE + 1];
}
void
kdi_flush_caches(void)
{}
void
mmu_init_kernel_pgsz(struct hat *hat)
{
}
size_t
mmu_get_kernel_lpsize(size_t value)
{
return (value);
}