/* SPDX-License-Identifier: GPL-2.0 */ /* * Copyright (c) 2023 Meta Platforms, Inc. and affiliates * Copyright (c) 2023 Intel and affiliates */ #ifndef __DPLL_CORE_H__ #define __DPLL_CORE_H__ #include #include #include #include "dpll_nl.h" #define DPLL_REGISTERED XA_MARK_1 /** * struct dpll_device - stores DPLL device internal data * @id: unique id number for device given by dpll subsystem * @device_idx: id given by dev driver * @clock_id: unique identifier (clock_id) of a dpll * @module: module of creator * @type: type of a dpll * @pin_refs: stores pins registered within a dpll * @refcount: refcount * @registration_list: list of registered ops and priv data of dpll owners **/ struct dpll_device { u32 id; u32 device_idx; u64 clock_id; struct module *module; enum dpll_type type; struct xarray pin_refs; refcount_t refcount; struct list_head registration_list; }; /** * struct dpll_pin - structure for a dpll pin * @id: unique id number for pin given by dpll subsystem * @pin_idx: index of a pin given by dev driver * @clock_id: clock_id of creator * @module: module of creator * @dpll_refs: hold referencees to dplls pin was registered with * @parent_refs: hold references to parent pins pin was registered with * @prop: pin properties copied from the registerer * @rclk_dev_name: holds name of device when pin can recover clock from it * @refcount: refcount * @rcu: rcu_head for kfree_rcu() **/ struct dpll_pin { u32 id; u32 pin_idx; u64 clock_id; struct module *module; struct xarray dpll_refs; struct xarray parent_refs; struct dpll_pin_properties prop; refcount_t refcount; struct rcu_head rcu; }; /** * struct dpll_pin_ref - structure for referencing either dpll or pins * @dpll: pointer to a dpll * @pin: pointer to a pin * @registration_list: list of ops and priv data registered with the ref * @refcount: refcount **/ struct dpll_pin_ref { union { struct dpll_device *dpll; struct dpll_pin *pin; }; struct list_head registration_list; refcount_t refcount; }; void *dpll_priv(struct dpll_device *dpll); void *dpll_pin_on_dpll_priv(struct dpll_device *dpll, struct dpll_pin *pin); void *dpll_pin_on_pin_priv(struct dpll_pin *parent, struct dpll_pin *pin); const struct dpll_device_ops *dpll_device_ops(struct dpll_device *dpll); struct dpll_device *dpll_device_get_by_id(int id); const struct dpll_pin_ops *dpll_pin_ops(struct dpll_pin_ref *ref); struct dpll_pin_ref *dpll_xa_ref_dpll_first(struct xarray *xa_refs); extern struct xarray dpll_device_xa; extern struct xarray dpll_pin_xa; extern struct mutex dpll_lock; #endif