1*af558227Smiod /* $OpenBSD: memrange.h,v 1.10 2015/08/18 20:19:32 miod Exp $ */ 27868fed7Smatthieu /*- 37868fed7Smatthieu * Copyright (c) 1999 Michael Smith <msmith@freebsd.org> 47868fed7Smatthieu * All rights reserved. 57868fed7Smatthieu * 67868fed7Smatthieu * Redistribution and use in source and binary forms, with or without 77868fed7Smatthieu * modification, are permitted provided that the following conditions 87868fed7Smatthieu * are met: 97868fed7Smatthieu * 1. Redistributions of source code must retain the above copyright 107868fed7Smatthieu * notice, this list of conditions and the following disclaimer. 117868fed7Smatthieu * 2. Redistributions in binary form must reproduce the above copyright 127868fed7Smatthieu * notice, this list of conditions and the following disclaimer in the 137868fed7Smatthieu * documentation and/or other materials provided with the distribution. 147868fed7Smatthieu * 157868fed7Smatthieu * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 167868fed7Smatthieu * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 177868fed7Smatthieu * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 187868fed7Smatthieu * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 197868fed7Smatthieu * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 207868fed7Smatthieu * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 217868fed7Smatthieu * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 227868fed7Smatthieu * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 237868fed7Smatthieu * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 247868fed7Smatthieu * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 257868fed7Smatthieu * SUCH DAMAGE. 267868fed7Smatthieu */ 27bcd90ab2Smatthieu /* 28*af558227Smiod * Memory range attribute operations, performed on /dev/mem 29bcd90ab2Smatthieu */ 30bcd90ab2Smatthieu 31bcd90ab2Smatthieu /* Memory range attributes */ 32bcd90ab2Smatthieu #define MDF_UNCACHEABLE (1<<0) /* region not cached */ 33bcd90ab2Smatthieu #define MDF_WRITECOMBINE (1<<1) /* region supports "write combine" action */ 34bcd90ab2Smatthieu #define MDF_WRITETHROUGH (1<<2) /* write-through cached */ 35bcd90ab2Smatthieu #define MDF_WRITEBACK (1<<3) /* write-back cached */ 36bcd90ab2Smatthieu #define MDF_WRITEPROTECT (1<<4) /* read-only region */ 37a78a644dSmatthieu #define MDF_UNKNOWN (1<<5) /* any state we don't understand */ 38bcd90ab2Smatthieu #define MDF_ATTRMASK (0x00ffffff) 39bcd90ab2Smatthieu 40bcd90ab2Smatthieu #define MDF_FIXBASE (1<<24) /* fixed base */ 41bcd90ab2Smatthieu #define MDF_FIXLEN (1<<25) /* fixed length */ 42bcd90ab2Smatthieu #define MDF_FIRMWARE (1<<26) /* set by firmware (XXX not useful?) */ 43bcd90ab2Smatthieu #define MDF_ACTIVE (1<<27) /* currently active */ 44bcd90ab2Smatthieu #define MDF_BOGUS (1<<28) /* we don't like it */ 45bcd90ab2Smatthieu #define MDF_FIXACTIVE (1<<29) /* can't be turned off */ 46a78a644dSmatthieu #define MDF_FORCE (1<<31) /* force risky changes */ 47bcd90ab2Smatthieu 482160557bSderaadt struct mem_range_desc { 49bcd90ab2Smatthieu u_int64_t mr_base; 50bcd90ab2Smatthieu u_int64_t mr_len; 51bcd90ab2Smatthieu int mr_flags; 52bcd90ab2Smatthieu char mr_owner[8]; 53bcd90ab2Smatthieu }; 54bcd90ab2Smatthieu 552160557bSderaadt struct mem_range_op { 56bcd90ab2Smatthieu struct mem_range_desc *mo_desc; 57bcd90ab2Smatthieu int mo_arg[2]; 58bcd90ab2Smatthieu #define MEMRANGE_SET_UPDATE 0 59bcd90ab2Smatthieu #define MEMRANGE_SET_REMOVE 1 60bcd90ab2Smatthieu /* XXX want a flag that says "set and undo when I exit" */ 61bcd90ab2Smatthieu }; 62bcd90ab2Smatthieu 63bcd90ab2Smatthieu #define MEMRANGE_GET _IOWR('m', 50, struct mem_range_op) 64bcd90ab2Smatthieu #define MEMRANGE_SET _IOW('m', 51, struct mem_range_op) 65bcd90ab2Smatthieu 66e1ad8ac7Skettenis /* Offset indicating a write combining mapping is requested. */ 67e1ad8ac7Skettenis #define MEMRANGE_WC_RANGE 0x4000000000000000ULL 68e1ad8ac7Skettenis 69bcd90ab2Smatthieu #ifdef _KERNEL 70bcd90ab2Smatthieu 71bcd90ab2Smatthieu struct mem_range_softc; 722160557bSderaadt struct mem_range_ops { 73c4071fd1Smillert void (*init)(struct mem_range_softc *sc); 742160557bSderaadt int (*set)(struct mem_range_softc *sc, 752160557bSderaadt struct mem_range_desc *mrd, int *arg); 76c4071fd1Smillert void (*initAP)(struct mem_range_softc *sc); 77fb47c0a7Skettenis void (*reload)(struct mem_range_softc *sc); 78bcd90ab2Smatthieu }; 79bcd90ab2Smatthieu 802160557bSderaadt struct mem_range_softc { 81bcd90ab2Smatthieu struct mem_range_ops *mr_op; 82bcd90ab2Smatthieu int mr_cap; 83bcd90ab2Smatthieu int mr_ndesc; 84bcd90ab2Smatthieu struct mem_range_desc *mr_desc; 85bcd90ab2Smatthieu }; 86bcd90ab2Smatthieu 87bcd90ab2Smatthieu extern struct mem_range_softc mem_range_softc; 88bcd90ab2Smatthieu 89bcd90ab2Smatthieu __BEGIN_DECLS 909a2348d8Sderaadt extern void mem_range_attach(void); 91c4071fd1Smillert extern int mem_range_attr_get(struct mem_range_desc *mrd, int *arg); 92c4071fd1Smillert extern int mem_range_attr_set(struct mem_range_desc *mrd, int *arg); 93c4071fd1Smillert extern void mem_range_AP_init(void); 94fb47c0a7Skettenis extern void mem_range_reload(void); 95bcd90ab2Smatthieu __END_DECLS 962160557bSderaadt #endif /* _KERNEL */ 97bcd90ab2Smatthieu 98