mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-13 14:36:09 +07:00
422dcafe47
Lochnagar is an evaluation and development board for Cirrus Logic Smart CODEC and Amp devices. It allows the connection of most Cirrus Logic devices on mini-cards, as well as allowing connection of various application processor systems to provide a full evaluation platform. This driver supports the board controller chip on the Lochnagar board. Audio system topology, clocking and power can all be controlled through the Lochnagar controller chip, allowing the device under test to be used in a variety of possible use cases. As the Lochnagar is a fairly complex device this MFD driver allows the drivers for the various features to be bound in. Initially clocking, regulator and pinctrl will be added as these are necessary to configure the system. But in time at least audio and voltage/current monitoring will also be added. Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com> Signed-off-by: Lee Jones <lee.jones@linaro.org>
56 lines
1.6 KiB
C
56 lines
1.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Lochnagar internals
|
|
*
|
|
* Copyright (c) 2013-2018 Cirrus Logic, Inc. and
|
|
* Cirrus Logic International Semiconductor Ltd.
|
|
*
|
|
* Author: Charles Keepax <ckeepax@opensource.cirrus.com>
|
|
*/
|
|
|
|
#include <linux/device.h>
|
|
#include <linux/mutex.h>
|
|
#include <linux/regmap.h>
|
|
|
|
#ifndef CIRRUS_LOCHNAGAR_H
|
|
#define CIRRUS_LOCHNAGAR_H
|
|
|
|
enum lochnagar_type {
|
|
LOCHNAGAR1,
|
|
LOCHNAGAR2,
|
|
};
|
|
|
|
/**
|
|
* struct lochnagar - Core data for the Lochnagar audio board driver.
|
|
*
|
|
* @type: The type of Lochnagar device connected.
|
|
* @dev: A pointer to the struct device for the main MFD.
|
|
* @regmap: The devices main register map.
|
|
* @analogue_config_lock: Lock used to protect updates in the analogue
|
|
* configuration as these must not be changed whilst the hardware is processing
|
|
* the last update.
|
|
*/
|
|
struct lochnagar {
|
|
enum lochnagar_type type;
|
|
struct device *dev;
|
|
struct regmap *regmap;
|
|
|
|
/* Lock to protect updates to the analogue configuration */
|
|
struct mutex analogue_config_lock;
|
|
};
|
|
|
|
/* Register Addresses */
|
|
#define LOCHNAGAR_SOFTWARE_RESET 0x00
|
|
#define LOCHNAGAR_FIRMWARE_ID1 0x01
|
|
#define LOCHNAGAR_FIRMWARE_ID2 0x02
|
|
|
|
/* (0x0000) Software Reset */
|
|
#define LOCHNAGAR_DEVICE_ID_MASK 0xFFFC
|
|
#define LOCHNAGAR_DEVICE_ID_SHIFT 2
|
|
#define LOCHNAGAR_REV_ID_MASK 0x0003
|
|
#define LOCHNAGAR_REV_ID_SHIFT 0
|
|
|
|
int lochnagar_update_config(struct lochnagar *lochnagar);
|
|
|
|
#endif
|