1/* $OpenBSD: wsfb_driver.c,v 1.18 2003/04/02 16:42:13 jason Exp $ */ 2/* 3 * Copyright (c) 2024 Michael Lorenz 4 * All rights reserved. 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions 8 * are met: 9 * 10 * - Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * - Redistributions in binary form must reproduce the above 13 * copyright notice, this list of conditions and the following 14 * disclaimer in the documentation and/or other materials provided 15 * with the distribution. 16 * 17 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 18 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 19 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 20 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 21 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 23 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 24 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 25 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 26 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 27 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 28 * POSSIBILITY OF SUCH DAMAGE. 29 * 30 */ 31 32#include <fcntl.h> 33#include <sys/types.h> 34#include <sys/time.h> 35#include <dev/wscons/wsconsio.h> 36 37#include "xorg-server.h" 38#include "xf86.h" 39#include "xf86_OSproc.h" 40#include "compiler.h" 41#include "xorgVersion.h" 42#include "xf86Cursor.h" 43#include "exa.h" 44#include "compat-api.h" 45 46#ifndef NGLE_H 47#define NGLE_H 48 49/* private data */ 50typedef struct { 51 int fd; 52 struct wsdisplayio_fbinfo fbi; 53 unsigned char* fbmem; 54 size_t fbmem_len; 55 void *regs; 56 size_t reglen; 57 Bool HWCursor; 58 CloseScreenProcPtr CloseScreen; 59 CreateScreenResourcesProcPtr CreateScreenResources; 60 EntityInfoPtr pEnt; 61 struct wsdisplay_cursor cursor; 62 int maskoffset; 63 xf86CursorInfoPtr CursorInfoRec; 64 OptionInfoPtr Options; 65 ExaDriverPtr pExa; 66 GlyphsProcPtr glyphs; 67 uint32_t gid, buf, fbacc, creg; 68 int offset, hwmode, offsetd; 69#define HW_FB 0 70#define HW_FILL 1 71#define HW_BLIT 2 72#define HW_BINC 3 73 uint32_t read_mode, write_mode; 74 int need_sync; 75} NGLERec, *NGLEPtr; 76 77#define NGLEPTR(p) ((NGLEPtr)((p)->driverPrivate)) 78 79Bool NGLESetupCursor(ScreenPtr); 80Bool NGLEInitAccel(ScreenPtr); 81Bool SummitSetupCursor(ScreenPtr); 82Bool SummitInitAccel(ScreenPtr); 83 84static inline void 85NGLEWrite4(NGLEPtr fPtr, int offset, uint32_t val) 86{ 87 volatile uint32_t *ptr = (uint32_t *)((uint8_t *)fPtr->regs + offset); 88 *ptr = val; 89} 90 91static inline void 92NGLEWrite1(NGLEPtr fPtr, int offset, uint8_t val) 93{ 94 volatile uint8_t *ptr = (uint8_t *)fPtr->regs + offset; 95 *ptr = val; 96} 97 98static inline uint32_t 99NGLERead4(NGLEPtr fPtr, int offset) 100{ 101 volatile uint32_t *ptr = (uint32_t *)((uint8_t *)fPtr->regs + offset); 102 return *ptr; 103} 104 105static inline uint8_t 106NGLERead1(NGLEPtr fPtr, int offset) 107{ 108 volatile uint8_t *ptr = (uint8_t *)fPtr->regs + offset; 109 return *ptr; 110} 111 112#endif 113