root/usr/src/uts/common/io/igc/igc_osdep.c
/*
 * This file and its contents are supplied under the terms of the
 * Common Development and Distribution License ("CDDL"), version 1.0.
 * You may only use this file in accordance with the terms of version
 * 1.0 of the CDDL.
 *
 * A full copy of the text of the CDDL should have accompanied this
 * source.  A copy of the CDDL is also available via the Internet at
 * http://www.illumos.org/license/CDDL.
 */

/*
 * Copyright 2024 Oxide Computer Company
 */

/*
 * Implementation of the various igc functionality that is required by the core
 * code.
 */

#include "igc.h"

/*
 * Set to 1 if you want the igc core logic actually written out. Otherwise this
 * serves as a DTrace point.
 */
uint32_t igc_core_debug = 0;

void
igc_core_log(struct igc_hw *hw, const char *fmt, ...)
{
        igc_t *igc = hw->back;

        if (igc_core_debug != 0) {
                va_list ap;

                va_start(ap, fmt);
                vdev_err(igc->igc_dip, CE_WARN, fmt, ap);
                va_end(ap);
        }
}

uint32_t
IGC_READ_REG(struct igc_hw *hw, uint32_t reg)
{
        igc_t *igc = hw->back;

        return (igc_read32(igc, reg));
}

void
IGC_WRITE_REG(struct igc_hw *hw, uint32_t reg, uint32_t val)
{
        igc_t *igc = hw->back;

        igc_write32(igc, reg, val);
}

void
IGC_WRITE_REG_ARRAY(struct igc_hw *hw, uint32_t reg, uint32_t offset,
    uint32_t val)
{
        igc_t *igc = hw->back;

        ASSERT3U(reg, <, igc->igc_regs_size);
        ASSERT3U(offset + reg, <=, igc->igc_regs_size);
        igc_write32(igc, reg + offset, val);
}