mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-03-22 07:27:12 +08:00
Introduce zl3073x_dev_output_pin_freq_get() helper function to compute the output pin frequency based on synthesizer frequency, output divisor, and signal format. For N-div signal formats, the N-pin frequency is additionally divided by esync_n_period. Add zl3073x_out_is_ndiv() helper to check if an output is configured in N-div mode (2_NDIV or 2_NDIV_INV signal formats). Refactor zl3073x_dpll_output_pin_frequency_get() callback to use the new helper, reducing code duplication and enabling reuse of the frequency calculation logic in other contexts. This is a preparatory change for adding current frequency to the supported frequencies list in pin properties. Signed-off-by: Ivan Vecera <ivecera@redhat.com> Link: https://patch.msgid.link/20260205154350.3180465-2-ivecera@redhat.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
111 lines
2.6 KiB
C
111 lines
2.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
|
|
#ifndef _ZL3073X_OUT_H
|
|
#define _ZL3073X_OUT_H
|
|
|
|
#include <linux/bitfield.h>
|
|
#include <linux/types.h>
|
|
|
|
#include "regs.h"
|
|
|
|
struct zl3073x_dev;
|
|
|
|
/**
|
|
* struct zl3073x_out - output state
|
|
* @div: output divisor
|
|
* @width: output pulse width
|
|
* @esync_n_period: embedded sync or n-pin period (for n-div formats)
|
|
* @esync_n_width: embedded sync or n-pin pulse width
|
|
* @phase_comp: phase compensation
|
|
* @ctrl: output control
|
|
* @mode: output mode
|
|
*/
|
|
struct zl3073x_out {
|
|
u32 div;
|
|
u32 width;
|
|
u32 esync_n_period;
|
|
u32 esync_n_width;
|
|
s32 phase_comp;
|
|
u8 ctrl;
|
|
u8 mode;
|
|
};
|
|
|
|
int zl3073x_out_state_fetch(struct zl3073x_dev *zldev, u8 index);
|
|
const struct zl3073x_out *zl3073x_out_state_get(struct zl3073x_dev *zldev,
|
|
u8 index);
|
|
|
|
int zl3073x_out_state_set(struct zl3073x_dev *zldev, u8 index,
|
|
const struct zl3073x_out *out);
|
|
|
|
/**
|
|
* zl3073x_out_signal_format_get - get output signal format
|
|
* @out: pointer to out state
|
|
*
|
|
* Return: signal format of given output
|
|
*/
|
|
static inline u8 zl3073x_out_signal_format_get(const struct zl3073x_out *out)
|
|
{
|
|
return FIELD_GET(ZL_OUTPUT_MODE_SIGNAL_FORMAT, out->mode);
|
|
}
|
|
|
|
/**
|
|
* zl3073x_out_is_diff - check if the given output is differential
|
|
* @out: pointer to out state
|
|
*
|
|
* Return: true if output is differential, false if output is single-ended
|
|
*/
|
|
static inline bool zl3073x_out_is_diff(const struct zl3073x_out *out)
|
|
{
|
|
switch (zl3073x_out_signal_format_get(out)) {
|
|
case ZL_OUTPUT_MODE_SIGNAL_FORMAT_LVDS:
|
|
case ZL_OUTPUT_MODE_SIGNAL_FORMAT_DIFF:
|
|
case ZL_OUTPUT_MODE_SIGNAL_FORMAT_LOWVCM:
|
|
return true;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* zl3073x_out_is_enabled - check if the given output is enabled
|
|
* @out: pointer to out state
|
|
*
|
|
* Return: true if output is enabled, false if output is disabled
|
|
*/
|
|
static inline bool zl3073x_out_is_enabled(const struct zl3073x_out *out)
|
|
{
|
|
return !!FIELD_GET(ZL_OUTPUT_CTRL_EN, out->ctrl);
|
|
}
|
|
|
|
/**
|
|
* zl3073x_out_is_ndiv - check if the given output is in N-div mode
|
|
* @out: pointer to out state
|
|
*
|
|
* Return: true if output is in N-div mode, false otherwise
|
|
*/
|
|
static inline bool zl3073x_out_is_ndiv(const struct zl3073x_out *out)
|
|
{
|
|
switch (zl3073x_out_signal_format_get(out)) {
|
|
case ZL_OUTPUT_MODE_SIGNAL_FORMAT_2_NDIV:
|
|
case ZL_OUTPUT_MODE_SIGNAL_FORMAT_2_NDIV_INV:
|
|
return true;
|
|
default:
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* zl3073x_out_synth_get - get synth connected to given output
|
|
* @out: pointer to out state
|
|
*
|
|
* Return: index of synth connected to given output.
|
|
*/
|
|
static inline u8 zl3073x_out_synth_get(const struct zl3073x_out *out)
|
|
{
|
|
return FIELD_GET(ZL_OUTPUT_CTRL_SYNTH_SEL, out->ctrl);
|
|
}
|
|
|
|
#endif /* _ZL3073X_OUT_H */
|