2000-09-29 13:46:07 +00:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 1998 Doug Rabson
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* $FreeBSD$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _MACHINE_MD_VAR_H_
|
|
|
|
#define _MACHINE_MD_VAR_H_
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Miscellaneous machine-dependent declarations.
|
|
|
|
*/
|
|
|
|
|
2004-07-10 22:59:30 +00:00
|
|
|
struct ia64_fdesc {
|
|
|
|
uint64_t func;
|
|
|
|
uint64_t gp;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define FDESC_FUNC(fn) (((struct ia64_fdesc *) fn)->func)
|
|
|
|
#define FDESC_GP(fn) (((struct ia64_fdesc *) fn)->gp)
|
|
|
|
|
|
|
|
/* Convenience macros to decompose CFM & ar.pfs. */
|
|
|
|
#define IA64_CFM_SOF(x) ((x) & 0x7f)
|
|
|
|
#define IA64_CFM_SOL(x) (((x) >> 7) & 0x7f)
|
|
|
|
#define IA64_CFM_SOR(x) (((x) >> 14) & 0x0f)
|
|
|
|
#define IA64_CFM_RRB_GR(x) (((x) >> 18) & 0x7f)
|
|
|
|
#define IA64_CFM_RRB_FR(x) (((x) >> 25) & 0x7f)
|
|
|
|
#define IA64_CFM_RRB_PR(x) (((x) >> 32) & 0x3f)
|
|
|
|
|
2010-02-14 16:56:24 +00:00
|
|
|
/* Convenience function (inline) to adjust backingstore pointers. */
|
2004-07-10 22:59:30 +00:00
|
|
|
static __inline uint64_t
|
|
|
|
ia64_bsp_adjust(uint64_t bsp, int nslots)
|
|
|
|
{
|
|
|
|
int bias = ((unsigned int)bsp & 0x1f8) >> 3;
|
|
|
|
nslots += (nslots + bias + 63*8) / 63 - 8;
|
|
|
|
return bsp + (nslots << 3);
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef _KERNEL
|
|
|
|
|
2004-08-11 02:35:06 +00:00
|
|
|
struct _special;
|
2012-07-08 18:00:22 +00:00
|
|
|
struct pcpu;
|
2003-08-16 16:57:57 +00:00
|
|
|
struct thread;
|
|
|
|
struct trapframe;
|
2000-09-29 13:46:07 +00:00
|
|
|
|
2010-02-14 16:56:24 +00:00
|
|
|
/*
|
|
|
|
* Return value from ia64_init. Describes stack to switch to.
|
|
|
|
*/
|
2008-02-04 02:21:33 +00:00
|
|
|
struct ia64_init_return {
|
|
|
|
uint64_t bspstore;
|
|
|
|
uint64_t sp;
|
|
|
|
};
|
|
|
|
|
2010-02-14 16:56:24 +00:00
|
|
|
extern uint64_t ia64_lapic_addr;
|
Hide the creation of phys_avail behind an API to make it easier to do it
correctly. We now iterate the EFI memory descriptors once and collect all
the information in a single pass. This includes:
1. The I/O port base address,
2. The PAL memory region. Have the physmem API track this.
3. Memory descriptors of memory we can't use, like bad memory, runtime
services code & data, etc. Have the physmem API track these.
4. memory descriptors of memory we can use or re-use, such as free
memory, boot time services code & data, loader code & data, etc.
These are added by the physmem API.
Since the PBVM page table and pages are in memory described as loader
data, inform the physmem API of chunks that need to be delated from the
available physical memory.
While here, remove Maxmem and replace it with the better named paddr_max.
Maxmem was defined as physmem, which is generally wrong. Now, paddr_max
is properly defined as the largesty physical address.
The upshot of all this is that:
1. We properly determine realmem.
2. We maximize physmem by re-using memory where possible.
3. We remove complexity from ia64_init() in machdep.c.
4. Remove confusion about realmem, physmem & Maxmem.
The new ia64_physmem_alloc() is to replace pmap_steal_memory() in pmap.c,
as well as replace the handcrafted allocation of the VHPT for the BSP in
pmap_bootstrap() in pmap.c. This is step 2 and addresses the manipulation
of phys_avail after it is being created.
2012-07-07 00:25:17 +00:00
|
|
|
extern vm_paddr_t paddr_max;
|
2010-06-11 03:00:32 +00:00
|
|
|
extern u_int busdma_swi_pending;
|
2010-02-14 16:56:24 +00:00
|
|
|
|
2010-07-07 20:07:33 +00:00
|
|
|
void *acpi_find_table(const char *sig);
|
2002-03-20 23:30:31 +00:00
|
|
|
void busdma_swi(void);
|
2003-08-16 16:57:57 +00:00
|
|
|
int copyout_regstack(struct thread *, uint64_t *, uint64_t *);
|
|
|
|
void cpu_mp_add(u_int, u_int, u_int);
|
2012-07-08 18:00:22 +00:00
|
|
|
void cpu_pcpu_setup(struct pcpu *, u_int, u_int);
|
2003-08-16 16:57:57 +00:00
|
|
|
int do_ast(struct trapframe *);
|
2004-09-25 04:27:44 +00:00
|
|
|
void ia32_trap(int, struct trapframe *);
|
2003-08-16 16:57:57 +00:00
|
|
|
int ia64_count_cpus(void);
|
2006-06-29 19:59:18 +00:00
|
|
|
int ia64_emulate(struct trapframe *, struct thread *);
|
2005-07-05 17:12:18 +00:00
|
|
|
int ia64_flush_dirty(struct thread *, struct _special *);
|
2004-12-08 05:46:54 +00:00
|
|
|
uint64_t ia64_get_hcdp(void);
|
2003-08-16 16:57:57 +00:00
|
|
|
int ia64_highfp_drop(struct thread *);
|
2009-10-31 22:27:31 +00:00
|
|
|
int ia64_highfp_enable(struct thread *, struct trapframe *);
|
2003-08-16 16:57:57 +00:00
|
|
|
int ia64_highfp_save(struct thread *);
|
2009-10-31 22:27:31 +00:00
|
|
|
int ia64_highfp_save_ipi(void);
|
2008-02-04 02:21:33 +00:00
|
|
|
struct ia64_init_return ia64_init(void);
|
2009-12-23 04:48:42 +00:00
|
|
|
u_int ia64_itc_freq(void);
|
Hide the creation of phys_avail behind an API to make it easier to do it
correctly. We now iterate the EFI memory descriptors once and collect all
the information in a single pass. This includes:
1. The I/O port base address,
2. The PAL memory region. Have the physmem API track this.
3. Memory descriptors of memory we can't use, like bad memory, runtime
services code & data, etc. Have the physmem API track these.
4. memory descriptors of memory we can use or re-use, such as free
memory, boot time services code & data, loader code & data, etc.
These are added by the physmem API.
Since the PBVM page table and pages are in memory described as loader
data, inform the physmem API of chunks that need to be delated from the
available physical memory.
While here, remove Maxmem and replace it with the better named paddr_max.
Maxmem was defined as physmem, which is generally wrong. Now, paddr_max
is properly defined as the largesty physical address.
The upshot of all this is that:
1. We properly determine realmem.
2. We maximize physmem by re-using memory where possible.
3. We remove complexity from ia64_init() in machdep.c.
4. Remove confusion about realmem, physmem & Maxmem.
The new ia64_physmem_alloc() is to replace pmap_steal_memory() in pmap.c,
as well as replace the handcrafted allocation of the VHPT for the BSP in
pmap_bootstrap() in pmap.c. This is step 2 and addresses the manipulation
of phys_avail after it is being created.
2012-07-07 00:25:17 +00:00
|
|
|
int ia64_physmem_add(vm_paddr_t, vm_size_t);
|
2012-07-07 05:17:43 +00:00
|
|
|
void *ia64_physmem_alloc(vm_size_t, vm_size_t);
|
Hide the creation of phys_avail behind an API to make it easier to do it
correctly. We now iterate the EFI memory descriptors once and collect all
the information in a single pass. This includes:
1. The I/O port base address,
2. The PAL memory region. Have the physmem API track this.
3. Memory descriptors of memory we can't use, like bad memory, runtime
services code & data, etc. Have the physmem API track these.
4. memory descriptors of memory we can use or re-use, such as free
memory, boot time services code & data, loader code & data, etc.
These are added by the physmem API.
Since the PBVM page table and pages are in memory described as loader
data, inform the physmem API of chunks that need to be delated from the
available physical memory.
While here, remove Maxmem and replace it with the better named paddr_max.
Maxmem was defined as physmem, which is generally wrong. Now, paddr_max
is properly defined as the largesty physical address.
The upshot of all this is that:
1. We properly determine realmem.
2. We maximize physmem by re-using memory where possible.
3. We remove complexity from ia64_init() in machdep.c.
4. Remove confusion about realmem, physmem & Maxmem.
The new ia64_physmem_alloc() is to replace pmap_steal_memory() in pmap.c,
as well as replace the handcrafted allocation of the VHPT for the BSP in
pmap_bootstrap() in pmap.c. This is step 2 and addresses the manipulation
of phys_avail after it is being created.
2012-07-07 00:25:17 +00:00
|
|
|
int ia64_physmem_delete(vm_paddr_t, vm_size_t);
|
|
|
|
int ia64_physmem_fini(void);
|
|
|
|
int ia64_physmem_init(void);
|
|
|
|
int ia64_physmem_track(vm_paddr_t, vm_size_t);
|
2003-08-16 16:57:57 +00:00
|
|
|
void ia64_probe_sapics(void);
|
2009-05-18 18:44:54 +00:00
|
|
|
void ia64_sync_icache(vm_offset_t, vm_size_t);
|
2007-08-06 05:11:01 +00:00
|
|
|
void interrupt(struct trapframe *);
|
2003-08-16 16:57:57 +00:00
|
|
|
void map_gateway_page(void);
|
|
|
|
void map_pal_code(void);
|
2007-07-30 22:12:53 +00:00
|
|
|
void map_vhpt(uintptr_t);
|
2002-05-05 08:14:32 +00:00
|
|
|
void os_boot_rendez(void);
|
|
|
|
void os_mca(void);
|
2003-08-16 16:57:57 +00:00
|
|
|
int syscall(struct trapframe *);
|
|
|
|
void trap(int, struct trapframe *);
|
2004-09-25 04:27:44 +00:00
|
|
|
void trap_panic(int, struct trapframe *);
|
2003-10-23 06:20:38 +00:00
|
|
|
int unaligned_fixup(struct trapframe *, struct thread *);
|
2000-09-29 13:46:07 +00:00
|
|
|
|
2004-07-10 22:59:30 +00:00
|
|
|
#endif /* _KERNEL */
|
|
|
|
|
2000-09-29 13:46:07 +00:00
|
|
|
#endif /* !_MACHINE_MD_VAR_H_ */
|