1
0
mirror of https://github.com/corundum/corundum.git synced 2025-01-16 08:12:53 +08:00
corundum/lib/mqnic/mqnic_clk_info.c
Alex Forencich 448fa8eb4c Use SPDX
Signed-off-by: Alex Forencich <alex@alexforencich.com>
2023-06-26 11:44:57 -07:00

87 lines
2.6 KiB
C

// SPDX-License-Identifier: BSD-2-Clause-Views
/*
* Copyright (c) 2022-2023 The Regents of the University of California
*/
#include "mqnic.h"
void mqnic_clk_info_init(struct mqnic *dev)
{
dev->clk_info_rb = mqnic_find_reg_block(dev->rb_list, MQNIC_RB_CLK_INFO_TYPE, MQNIC_RB_CLK_INFO_VER, 0);
if (!dev->clk_info_rb)
return;
uint32_t val = mqnic_reg_read32(dev->clk_info_rb->regs, MQNIC_RB_CLK_INFO_REF_NOM_PER);
dev->ref_clk_nom_per_ns_num = val >> 16;
dev->ref_clk_nom_per_ns_denom = val & 0xffff;
dev->ref_clk_nom_freq_hz = (dev->ref_clk_nom_per_ns_denom * 1000000000ull) / dev->ref_clk_nom_per_ns_num;
val = mqnic_reg_read32(dev->clk_info_rb->regs, MQNIC_RB_CLK_INFO_CLK_NOM_PER);
dev->core_clk_nom_per_ns_num = val >> 16;
dev->core_clk_nom_per_ns_denom = val & 0xffff;
dev->core_clk_nom_freq_hz = (dev->core_clk_nom_per_ns_denom * 1000000000ull) / dev->core_clk_nom_per_ns_num;
dev->clk_info_channels = mqnic_reg_read32(dev->clk_info_rb->regs, MQNIC_RB_CLK_INFO_COUNT);
}
uint32_t mqnic_get_core_clk_nom_freq_hz(struct mqnic *dev)
{
return dev->core_clk_nom_freq_hz;
}
uint32_t mqnic_get_ref_clk_nom_freq_hz(struct mqnic *dev)
{
return dev->ref_clk_nom_freq_hz;
}
uint32_t mqnic_get_core_clk_freq_hz(struct mqnic *dev)
{
if (!dev->clk_info_rb)
return 0;
return mqnic_reg_read32(dev->clk_info_rb->regs, MQNIC_RB_CLK_INFO_CLK_FREQ);
}
uint32_t mqnic_get_clk_freq_hz(struct mqnic *dev, int ch)
{
if (!dev->clk_info_rb || ch < 0 || ch >= dev->clk_info_channels)
return 0;
return mqnic_reg_read32(dev->clk_info_rb->regs, MQNIC_RB_CLK_INFO_FREQ_BASE + ch*4);
}
uint64_t mqnic_core_clk_cycles_to_ns(struct mqnic *dev, uint64_t cycles)
{
if (!dev->clk_info_rb || !dev->core_clk_nom_per_ns_denom)
return 0;
return (cycles * (uint64_t)dev->core_clk_nom_per_ns_num) / (uint64_t)dev->core_clk_nom_per_ns_denom;
}
uint64_t mqnic_core_clk_ns_to_cycles(struct mqnic *dev, uint64_t ns)
{
if (!dev->clk_info_rb || !dev->core_clk_nom_per_ns_num)
return 0;
return (ns * (uint64_t)dev->core_clk_nom_per_ns_denom) / (uint64_t)dev->core_clk_nom_per_ns_num;
}
uint64_t mqnic_ref_clk_cycles_to_ns(struct mqnic *dev, uint64_t cycles)
{
if (!dev->clk_info_rb || !dev->ref_clk_nom_per_ns_denom)
return 0;
return (cycles * (uint64_t)dev->ref_clk_nom_per_ns_num) / (uint64_t)dev->ref_clk_nom_per_ns_denom;
}
uint64_t mqnic_ref_clk_ns_to_cycles(struct mqnic *dev, uint64_t ns)
{
if (!dev->clk_info_rb || !dev->ref_clk_nom_per_ns_num)
return 0;
return (ns * (uint64_t)dev->ref_clk_nom_per_ns_denom) / (uint64_t)dev->ref_clk_nom_per_ns_num;
}