xref: /openbsd-src/sys/arch/sparc64/include/sparc64.h (revision c45efb56f226b22b7f177f54962894827018cd63)
1*c45efb56Sdlg /*	$OpenBSD: sparc64.h,v 1.14 2018/08/28 00:00:42 dlg Exp $	*/
2df39fa9dSjason /*	$NetBSD: sparc64.h,v 1.3 2000/10/20 05:47:03 mrg Exp $	*/
3df39fa9dSjason 
4df39fa9dSjason /*
5df39fa9dSjason  * Copyright (C) 1996 Wolfgang Solfrank.
6df39fa9dSjason  * Copyright (C) 1996 TooLs GmbH.
7df39fa9dSjason  * All rights reserved.
8df39fa9dSjason  *
9df39fa9dSjason  * Redistribution and use in source and binary forms, with or without
10df39fa9dSjason  * modification, are permitted provided that the following conditions
11df39fa9dSjason  * are met:
12df39fa9dSjason  * 1. Redistributions of source code must retain the above copyright
13df39fa9dSjason  *    notice, this list of conditions and the following disclaimer.
14df39fa9dSjason  * 2. Redistributions in binary form must reproduce the above copyright
15df39fa9dSjason  *    notice, this list of conditions and the following disclaimer in the
16df39fa9dSjason  *    documentation and/or other materials provided with the distribution.
17df39fa9dSjason  * 3. All advertising materials mentioning features or use of this software
18df39fa9dSjason  *    must display the following acknowledgement:
19df39fa9dSjason  *	This product includes software developed by TooLs GmbH.
20df39fa9dSjason  * 4. The name of TooLs GmbH may not be used to endorse or promote products
21df39fa9dSjason  *    derived from this software without specific prior written permission.
22df39fa9dSjason  *
23df39fa9dSjason  * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
24df39fa9dSjason  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
25df39fa9dSjason  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
26df39fa9dSjason  * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
27df39fa9dSjason  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
28df39fa9dSjason  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
29df39fa9dSjason  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
30df39fa9dSjason  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
31df39fa9dSjason  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
32df39fa9dSjason  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33df39fa9dSjason  */
34df39fa9dSjason #ifndef	_MACHINE_SPARC64_H_
35df39fa9dSjason #define	_MACHINE_SPARC64_H_
36df39fa9dSjason 
37df39fa9dSjason struct mem_region {
38df39fa9dSjason 	u_int64_t start;
39df39fa9dSjason 	u_int64_t size;
40df39fa9dSjason };
41df39fa9dSjason 
424a593c83Skettenis int prom_set_trap_table(vaddr_t tba, paddr_t mmfsa);
43c4071fd1Smillert paddr_t prom_vtop(vaddr_t vaddr);
44c4071fd1Smillert vaddr_t prom_claim_virt(vaddr_t vaddr, int len);
45c4071fd1Smillert vaddr_t prom_alloc_virt(int len, int align);
46c4071fd1Smillert int prom_free_virt(vaddr_t vaddr, int len);
47c4071fd1Smillert int prom_unmap_virt(vaddr_t vaddr, int len);
48c4071fd1Smillert int prom_map_phys(paddr_t paddr, off_t size, vaddr_t vaddr, int mode);
49c4071fd1Smillert paddr_t prom_alloc_phys(int len, int align);
50c4071fd1Smillert paddr_t prom_claim_phys(paddr_t phys, int len);
51c4071fd1Smillert int prom_free_phys(paddr_t paddr, int len);
52c4071fd1Smillert paddr_t prom_get_msgbuf(int len, int align);
53333a4656Skettenis int prom_itlb_load(int index, u_int64_t data, vaddr_t vaddr);
54333a4656Skettenis int prom_dtlb_load(int index, u_int64_t data, vaddr_t vaddr);
55727e71d4Skettenis void prom_start_cpu(int cpu, void *func, long arg);
56727e71d4Skettenis void prom_start_cpu_by_cpuid(int cpu, void *func, long arg);
5737344b84Skettenis const char *prom_serengeti_set_console_input(const char *);
58c1c1037eSkettenis uint64_t prom_set_sun4v_api_version(uint64_t, uint64_t, uint64_t, uint64_t *);
590aa7a4daSkettenis void prom_sun4v_soft_state_supported(void);
60df39fa9dSjason 
61df39fa9dSjason /*
62df39fa9dSjason  * Debug
63df39fa9dSjason  */
64c4071fd1Smillert void prom_printf(const char *, ...);
65df39fa9dSjason #endif	/* _MACHINE_SPARC64_H_ */
66