/* SPDX-License-Identifier: GPL-2.0 */1/*2* auxio.h: Definitions and code for the Auxiliary I/O register.3*4* Copyright (C) 1995 David S. Miller ([email protected])5*/6#ifndef _SPARC_AUXIO_H7#define _SPARC_AUXIO_H89#include <asm/vaddrs.h>1011/* This register is an unsigned char in IO space. It does two things.12* First, it is used to control the front panel LED light on machines13* that have it (good for testing entry points to trap handlers and irq's)14* Secondly, it controls various floppy drive parameters.15*/16#define AUXIO_ORMEIN 0xf0 /* All writes must set these bits. */17#define AUXIO_ORMEIN4M 0xc0 /* sun4m - All writes must set these bits. */18#define AUXIO_FLPY_DENS 0x20 /* Floppy density, high if set. Read only. */19#define AUXIO_FLPY_DCHG 0x10 /* A disk change occurred. Read only. */20#define AUXIO_EDGE_ON 0x10 /* sun4m - On means Jumper block is in. */21#define AUXIO_FLPY_DSEL 0x08 /* Drive select/start-motor. Write only. */22#define AUXIO_LINK_TEST 0x08 /* sun4m - On means TPE Carrier detect. */2324/* Set the following to one, then zero, after doing a pseudo DMA transfer. */25#define AUXIO_FLPY_TCNT 0x04 /* Floppy terminal count. Write only. */2627/* Set the following to zero to eject the floppy. */28#define AUXIO_FLPY_EJCT 0x02 /* Eject floppy disk. Write only. */29#define AUXIO_LED 0x01 /* On if set, off if unset. Read/Write */3031#ifndef __ASSEMBLY__3233/*34* NOTE: these routines are implementation dependent--35* understand the hardware you are querying!36*/37void set_auxio(unsigned char bits_on, unsigned char bits_off);38unsigned char get_auxio(void); /* .../asm/floppy.h */3940/*41* The following routines are provided for driver-compatibility42* with sparc64 (primarily sunlance.c)43*/4445#define AUXIO_LTE_ON 146#define AUXIO_LTE_OFF 04748/* auxio_set_lte - Set Link Test Enable (TPE Link Detect)49*50* on - AUXIO_LTE_ON or AUXIO_LTE_OFF51*/52#define auxio_set_lte(on) \53do { \54if(on) { \55set_auxio(AUXIO_LINK_TEST, 0); \56} else { \57set_auxio(0, AUXIO_LINK_TEST); \58} \59} while (0)6061#define AUXIO_LED_ON 162#define AUXIO_LED_OFF 06364/* auxio_set_led - Set system front panel LED65*66* on - AUXIO_LED_ON or AUXIO_LED_OFF67*/68#define auxio_set_led(on) \69do { \70if(on) { \71set_auxio(AUXIO_LED, 0); \72} else { \73set_auxio(0, AUXIO_LED); \74} \75} while (0)7677#endif /* !(__ASSEMBLY__) */787980/* AUXIO2 (Power Off Control) */81extern volatile u8 __iomem *auxio_power_register;8283#define AUXIO_POWER_DETECT_FAILURE 3284#define AUXIO_POWER_CLEAR_FAILURE 285#define AUXIO_POWER_OFF 1868788#endif /* !(_SPARC_AUXIO_H) */899091