/* * Shared helper functions for devices from the ADAU family * * Copyright 2011-2016 Analog Devices Inc. * Author: Lars-Peter Clausen * * Licensed under the GPL-2 or later. */ #include #include #include #include "adau-utils.h" int adau_calc_pll_cfg(unsigned int freq_in, unsigned int freq_out, uint8_t regs[5]) { unsigned int r, n, m, i, j; unsigned int div; if (!freq_out) { r = 0; n = 0; m = 0; div = 0; } else { if (freq_out % freq_in != 0) { div = DIV_ROUND_UP(freq_in, 13500000); freq_in /= div; r = freq_out / freq_in; i = freq_out % freq_in; j = gcd(i, freq_in); n = i / j; m = freq_in / j; div--; } else { r = freq_out / freq_in; n = 0; m = 0; div = 0; } if (n > 0xffff || m > 0xffff || div > 3 || r > 8 || r < 2) return -EINVAL; } regs[0] = m >> 8; regs[1] = m & 0xff; regs[2] = n >> 8; regs[3] = n & 0xff; regs[4] = (r << 3) | (div << 1); if (m != 0) regs[4] |= 1; /* Fractional mode */ return 0; } EXPORT_SYMBOL_GPL(adau_calc_pll_cfg); MODULE_DESCRIPTION("ASoC ADAU audio CODECs shared helper functions"); MODULE_AUTHOR("Lars-Peter Clausen "); MODULE_LICENSE("GPL v2"); -loop-back'>packet-loop-back net-next plumbingsTobias Klauser
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGiovanni Cabiddu <giovanni.cabiddu@intel.com>2016-12-22 15:00:12 +0000
committerHerbert Xu <herbert@gondor.apana.org.au>2017-02-02 21:54:52 +0800
commit3484ecbe0e9deb94afb0b9b6172d77e98eb72b94 (patch)
tree4d4be0d20d4946c51ef47a882d78c9934a219c0e /sound/pci/au88x0/au88x0.h
parent11e3b725cfc282efe9d4a354153e99d86a16af08 (diff)
crypto: qat - fix bar discovery for c62x
Some accelerators of the c62x series have only two bars. This patch skips BAR0 if the accelerator does not have it. Cc: <stable@vger.kernel.org> Signed-off-by: Giovanni Cabiddu <giovanni.cabiddu@intel.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'sound/pci/au88x0/au88x0.h')