123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Copyright (C) STMicroelectronics SA 2015
- * Authors: Arnaud Pouliquen <[email protected]>
- * for STMicroelectronics.
- */
- #ifndef __SND_ST_AUD_UNIPERIF_H
- #define __SND_ST_AUD_UNIPERIF_H
- #include <linux/regmap.h>
- #include <sound/dmaengine_pcm.h>
- /*
- * Register access macros
- */
- #define GET_UNIPERIF_REG(ip, offset, shift, mask) \
- ((readl_relaxed(ip->base + offset) >> shift) & mask)
- #define SET_UNIPERIF_REG(ip, offset, shift, mask, value) \
- writel_relaxed(((readl_relaxed(ip->base + offset) & \
- ~(mask << shift)) | (((value) & mask) << shift)), ip->base + offset)
- #define SET_UNIPERIF_BIT_REG(ip, offset, shift, mask, value) \
- writel_relaxed((((value) & mask) << shift), ip->base + offset)
- /*
- * UNIPERIF_SOFT_RST reg
- */
- #define UNIPERIF_SOFT_RST_OFFSET(ip) 0x0000
- #define GET_UNIPERIF_SOFT_RST(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? \
- readl_relaxed(ip->base + UNIPERIF_SOFT_RST_OFFSET(ip)) : 0)
- #define SET_UNIPERIF_SOFT_RST(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_SOFT_RST_OFFSET(ip))
- /* SOFT_RST */
- #define UNIPERIF_SOFT_RST_SOFT_RST_SHIFT(ip) 0x0
- #define UNIPERIF_SOFT_RST_SOFT_RST_MASK(ip) 0x1
- #define SET_UNIPERIF_SOFT_RST_SOFT_RST(ip) \
- SET_UNIPERIF_BIT_REG(ip, \
- UNIPERIF_SOFT_RST_OFFSET(ip), \
- UNIPERIF_SOFT_RST_SOFT_RST_SHIFT(ip), \
- UNIPERIF_SOFT_RST_SOFT_RST_MASK(ip), 1)
- #define GET_UNIPERIF_SOFT_RST_SOFT_RST(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_SOFT_RST_OFFSET(ip), \
- UNIPERIF_SOFT_RST_SOFT_RST_SHIFT(ip), \
- UNIPERIF_SOFT_RST_SOFT_RST_MASK(ip))
- /*
- * UNIPERIF_FIFO_DATA reg
- */
- #define UNIPERIF_FIFO_DATA_OFFSET(ip) 0x0004
- #define SET_UNIPERIF_DATA(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_FIFO_DATA_OFFSET(ip))
- /*
- * UNIPERIF_CHANNEL_STA_REGN reg
- */
- #define UNIPERIF_CHANNEL_STA_REGN(ip, n) (0x0060 + (4 * n))
- #define GET_UNIPERIF_CHANNEL_STA_REGN(ip) \
- readl_relaxed(ip->base + UNIPERIF_CHANNEL_STA_REGN(ip, n))
- #define SET_UNIPERIF_CHANNEL_STA_REGN(ip, n, value) \
- writel_relaxed(value, ip->base + \
- UNIPERIF_CHANNEL_STA_REGN(ip, n))
- #define UNIPERIF_CHANNEL_STA_REG0_OFFSET(ip) 0x0060
- #define GET_UNIPERIF_CHANNEL_STA_REG0(ip) \
- readl_relaxed(ip->base + UNIPERIF_CHANNEL_STA_REG0_OFFSET(ip))
- #define SET_UNIPERIF_CHANNEL_STA_REG0(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_CHANNEL_STA_REG0_OFFSET(ip))
- #define UNIPERIF_CHANNEL_STA_REG1_OFFSET(ip) 0x0064
- #define GET_UNIPERIF_CHANNEL_STA_REG1(ip) \
- readl_relaxed(ip->base + UNIPERIF_CHANNEL_STA_REG1_OFFSET(ip))
- #define SET_UNIPERIF_CHANNEL_STA_REG1(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_CHANNEL_STA_REG1_OFFSET(ip))
- #define UNIPERIF_CHANNEL_STA_REG2_OFFSET(ip) 0x0068
- #define GET_UNIPERIF_CHANNEL_STA_REG2(ip) \
- readl_relaxed(ip->base + UNIPERIF_CHANNEL_STA_REG2_OFFSET(ip))
- #define SET_UNIPERIF_CHANNEL_STA_REG2(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_CHANNEL_STA_REG2_OFFSET(ip))
- #define UNIPERIF_CHANNEL_STA_REG3_OFFSET(ip) 0x006C
- #define GET_UNIPERIF_CHANNEL_STA_REG3(ip) \
- readl_relaxed(ip->base + UNIPERIF_CHANNEL_STA_REG3_OFFSET(ip))
- #define SET_UNIPERIF_CHANNEL_STA_REG3(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_CHANNEL_STA_REG3_OFFSET(ip))
- #define UNIPERIF_CHANNEL_STA_REG4_OFFSET(ip) 0x0070
- #define GET_UNIPERIF_CHANNEL_STA_REG4(ip) \
- readl_relaxed(ip->base + UNIPERIF_CHANNEL_STA_REG4_OFFSET(ip))
- #define SET_UNIPERIF_CHANNEL_STA_REG4(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_CHANNEL_STA_REG4_OFFSET(ip))
- #define UNIPERIF_CHANNEL_STA_REG5_OFFSET(ip) 0x0074
- #define GET_UNIPERIF_CHANNEL_STA_REG5(ip) \
- readl_relaxed(ip->base + UNIPERIF_CHANNEL_STA_REG5_OFFSET(ip))
- #define SET_UNIPERIF_CHANNEL_STA_REG5(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_CHANNEL_STA_REG5_OFFSET(ip))
- /*
- * UNIPERIF_ITS reg
- */
- #define UNIPERIF_ITS_OFFSET(ip) 0x000C
- #define GET_UNIPERIF_ITS(ip) \
- readl_relaxed(ip->base + UNIPERIF_ITS_OFFSET(ip))
- /* MEM_BLK_READ */
- #define UNIPERIF_ITS_MEM_BLK_READ_SHIFT(ip) 5
- #define UNIPERIF_ITS_MEM_BLK_READ_MASK(ip) \
- (BIT(UNIPERIF_ITS_MEM_BLK_READ_SHIFT(ip)))
- /* FIFO_ERROR */
- #define UNIPERIF_ITS_FIFO_ERROR_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 0 : 8)
- #define UNIPERIF_ITS_FIFO_ERROR_MASK(ip) \
- (BIT(UNIPERIF_ITS_FIFO_ERROR_SHIFT(ip)))
- /* DMA_ERROR */
- #define UNIPERIF_ITS_DMA_ERROR_SHIFT(ip) 9
- #define UNIPERIF_ITS_DMA_ERROR_MASK(ip) \
- (BIT(UNIPERIF_ITS_DMA_ERROR_SHIFT(ip)))
- /* UNDERFLOW_REC_DONE */
- #define UNIPERIF_ITS_UNDERFLOW_REC_DONE_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 12)
- #define UNIPERIF_ITS_UNDERFLOW_REC_DONE_MASK(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? \
- 0 : (BIT(UNIPERIF_ITS_UNDERFLOW_REC_DONE_SHIFT(ip))))
- /* UNDERFLOW_REC_FAILED */
- #define UNIPERIF_ITS_UNDERFLOW_REC_FAILED_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 13)
- #define UNIPERIF_ITS_UNDERFLOW_REC_FAILED_MASK(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? \
- 0 : (BIT(UNIPERIF_ITS_UNDERFLOW_REC_FAILED_SHIFT(ip))))
- /*
- * UNIPERIF_ITS_BCLR reg
- */
- /* FIFO_ERROR */
- #define UNIPERIF_ITS_BCLR_FIFO_ERROR_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 0 : 8)
- #define UNIPERIF_ITS_BCLR_FIFO_ERROR_MASK(ip) \
- (BIT(UNIPERIF_ITS_BCLR_FIFO_ERROR_SHIFT(ip)))
- #define SET_UNIPERIF_ITS_BCLR_FIFO_ERROR(ip) \
- SET_UNIPERIF_ITS_BCLR(ip, \
- UNIPERIF_ITS_BCLR_FIFO_ERROR_MASK(ip))
- #define UNIPERIF_ITS_BCLR_OFFSET(ip) 0x0010
- #define SET_UNIPERIF_ITS_BCLR(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_ITS_BCLR_OFFSET(ip))
- /*
- * UNIPERIF_ITM reg
- */
- #define UNIPERIF_ITM_OFFSET(ip) 0x0018
- #define GET_UNIPERIF_ITM(ip) \
- readl_relaxed(ip->base + UNIPERIF_ITM_OFFSET(ip))
- /* FIFO_ERROR */
- #define UNIPERIF_ITM_FIFO_ERROR_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 0 : 8)
- #define UNIPERIF_ITM_FIFO_ERROR_MASK(ip) \
- (BIT(UNIPERIF_ITM_FIFO_ERROR_SHIFT(ip)))
- /* UNDERFLOW_REC_DONE */
- #define UNIPERIF_ITM_UNDERFLOW_REC_DONE_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 12)
- #define UNIPERIF_ITM_UNDERFLOW_REC_DONE_MASK(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? \
- 0 : (BIT(UNIPERIF_ITM_UNDERFLOW_REC_DONE_SHIFT(ip))))
- /* UNDERFLOW_REC_FAILED */
- #define UNIPERIF_ITM_UNDERFLOW_REC_FAILED_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 13)
- #define UNIPERIF_ITM_UNDERFLOW_REC_FAILED_MASK(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? \
- 0 : (BIT(UNIPERIF_ITM_UNDERFLOW_REC_FAILED_SHIFT(ip))))
- /*
- * UNIPERIF_ITM_BCLR reg
- */
- #define UNIPERIF_ITM_BCLR_OFFSET(ip) 0x001c
- #define SET_UNIPERIF_ITM_BCLR(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_ITM_BCLR_OFFSET(ip))
- /* FIFO_ERROR */
- #define UNIPERIF_ITM_BCLR_FIFO_ERROR_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 0 : 8)
- #define UNIPERIF_ITM_BCLR_FIFO_ERROR_MASK(ip) \
- (BIT(UNIPERIF_ITM_BCLR_FIFO_ERROR_SHIFT(ip)))
- #define SET_UNIPERIF_ITM_BCLR_FIFO_ERROR(ip) \
- SET_UNIPERIF_ITM_BCLR(ip, \
- UNIPERIF_ITM_BCLR_FIFO_ERROR_MASK(ip))
- /* DMA_ERROR */
- #define UNIPERIF_ITM_BCLR_DMA_ERROR_SHIFT(ip) 9
- #define UNIPERIF_ITM_BCLR_DMA_ERROR_MASK(ip) \
- (BIT(UNIPERIF_ITM_BCLR_DMA_ERROR_SHIFT(ip)))
- #define SET_UNIPERIF_ITM_BCLR_DMA_ERROR(ip) \
- SET_UNIPERIF_ITM_BCLR(ip, \
- UNIPERIF_ITM_BCLR_DMA_ERROR_MASK(ip))
- /*
- * UNIPERIF_ITM_BSET reg
- */
- #define UNIPERIF_ITM_BSET_OFFSET(ip) 0x0020
- #define SET_UNIPERIF_ITM_BSET(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_ITM_BSET_OFFSET(ip))
- /* FIFO_ERROR */
- #define UNIPERIF_ITM_BSET_FIFO_ERROR_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 0 : 8)
- #define UNIPERIF_ITM_BSET_FIFO_ERROR_MASK(ip) \
- (BIT(UNIPERIF_ITM_BSET_FIFO_ERROR_SHIFT(ip)))
- #define SET_UNIPERIF_ITM_BSET_FIFO_ERROR(ip) \
- SET_UNIPERIF_ITM_BSET(ip, \
- UNIPERIF_ITM_BSET_FIFO_ERROR_MASK(ip))
- /* MEM_BLK_READ */
- #define UNIPERIF_ITM_BSET_MEM_BLK_READ_SHIFT(ip) 5
- #define UNIPERIF_ITM_BSET_MEM_BLK_READ_MASK(ip) \
- (BIT(UNIPERIF_ITM_BSET_MEM_BLK_READ_SHIFT(ip)))
- #define SET_UNIPERIF_ITM_BSET_MEM_BLK_READ(ip) \
- SET_UNIPERIF_ITM_BSET(ip, \
- UNIPERIF_ITM_BSET_MEM_BLK_READ_MASK(ip))
- /* DMA_ERROR */
- #define UNIPERIF_ITM_BSET_DMA_ERROR_SHIFT(ip) 9
- #define UNIPERIF_ITM_BSET_DMA_ERROR_MASK(ip) \
- (BIT(UNIPERIF_ITM_BSET_DMA_ERROR_SHIFT(ip)))
- #define SET_UNIPERIF_ITM_BSET_DMA_ERROR(ip) \
- SET_UNIPERIF_ITM_BSET(ip, \
- UNIPERIF_ITM_BSET_DMA_ERROR_MASK(ip))
- /* UNDERFLOW_REC_DONE */
- #define UNIPERIF_ITM_BSET_UNDERFLOW_REC_DONE_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 12)
- #define UNIPERIF_ITM_BSET_UNDERFLOW_REC_DONE_MASK(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? \
- 0 : (BIT(UNIPERIF_ITM_BSET_UNDERFLOW_REC_DONE_SHIFT(ip))))
- #define SET_UNIPERIF_ITM_BSET_UNDERFLOW_REC_DONE(ip) \
- SET_UNIPERIF_ITM_BSET(ip, \
- UNIPERIF_ITM_BSET_UNDERFLOW_REC_DONE_MASK(ip))
- /* UNDERFLOW_REC_FAILED */
- #define UNIPERIF_ITM_BSET_UNDERFLOW_REC_FAILED_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 13)
- #define UNIPERIF_ITM_BSET_UNDERFLOW_REC_FAILED_MASK(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? \
- 0 : (BIT(UNIPERIF_ITM_BSET_UNDERFLOW_REC_FAILED_SHIFT(ip))))
- #define SET_UNIPERIF_ITM_BSET_UNDERFLOW_REC_FAILED(ip) \
- SET_UNIPERIF_ITM_BSET(ip, \
- UNIPERIF_ITM_BSET_UNDERFLOW_REC_FAILED_MASK(ip))
- /*
- * UNIPERIF_CONFIG reg
- */
- #define UNIPERIF_CONFIG_OFFSET(ip) 0x0040
- #define GET_UNIPERIF_CONFIG(ip) \
- readl_relaxed(ip->base + UNIPERIF_CONFIG_OFFSET(ip))
- #define SET_UNIPERIF_CONFIG(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_CONFIG_OFFSET(ip))
- /* PARITY_CNTR */
- #define UNIPERIF_CONFIG_PARITY_CNTR_SHIFT(ip) 0
- #define UNIPERIF_CONFIG_PARITY_CNTR_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_PARITY_CNTR(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_PARITY_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_PARITY_CNTR_MASK(ip))
- #define SET_UNIPERIF_CONFIG_PARITY_CNTR_BY_HW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_PARITY_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_PARITY_CNTR_MASK(ip), 0)
- #define SET_UNIPERIF_CONFIG_PARITY_CNTR_BY_SW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_PARITY_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_PARITY_CNTR_MASK(ip), 1)
- /* CHANNEL_STA_CNTR */
- #define UNIPERIF_CONFIG_CHANNEL_STA_CNTR_SHIFT(ip) 1
- #define UNIPERIF_CONFIG_CHANNEL_STA_CNTR_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_CHANNEL_STA_CNTR(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_CHANNEL_STA_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_CHANNEL_STA_CNTR_MASK(ip))
- #define SET_UNIPERIF_CONFIG_CHANNEL_STA_CNTR_BY_SW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_CHANNEL_STA_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_CHANNEL_STA_CNTR_MASK(ip), 0)
- #define SET_UNIPERIF_CONFIG_CHANNEL_STA_CNTR_BY_HW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_CHANNEL_STA_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_CHANNEL_STA_CNTR_MASK(ip), 1)
- /* USER_DAT_CNTR */
- #define UNIPERIF_CONFIG_USER_DAT_CNTR_SHIFT(ip) 2
- #define UNIPERIF_CONFIG_USER_DAT_CNTR_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_USER_DAT_CNTR(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_USER_DAT_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_USER_DAT_CNTR_MASK(ip))
- #define SET_UNIPERIF_CONFIG_USER_DAT_CNTR_BY_HW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_USER_DAT_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_USER_DAT_CNTR_MASK(ip), 1)
- #define SET_UNIPERIF_CONFIG_USER_DAT_CNTR_BY_SW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_USER_DAT_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_USER_DAT_CNTR_MASK(ip), 0)
- /* VALIDITY_DAT_CNTR */
- #define UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_SHIFT(ip) 3
- #define UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_VALIDITY_DAT_CNTR(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_MASK(ip))
- #define SET_UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_BY_SW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_MASK(ip), 0)
- #define SET_UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_BY_HW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_SHIFT(ip), \
- UNIPERIF_CONFIG_VALIDITY_DAT_CNTR_MASK(ip), 1)
- /* ONE_BIT_AUD_SUPPORT */
- #define UNIPERIF_CONFIG_ONE_BIT_AUD_SHIFT(ip) 4
- #define UNIPERIF_CONFIG_ONE_BIT_AUD_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_ONE_BIT_AUD(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_ONE_BIT_AUD_SHIFT(ip), \
- UNIPERIF_CONFIG_ONE_BIT_AUD_MASK(ip))
- #define SET_UNIPERIF_CONFIG_ONE_BIT_AUD_DISABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_ONE_BIT_AUD_SHIFT(ip), \
- UNIPERIF_CONFIG_ONE_BIT_AUD_MASK(ip), 0)
- #define SET_UNIPERIF_CONFIG_ONE_BIT_AUD_ENABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_ONE_BIT_AUD_SHIFT(ip), \
- UNIPERIF_CONFIG_ONE_BIT_AUD_MASK(ip), 1)
- /* MEMORY_FMT */
- #define UNIPERIF_CONFIG_MEM_FMT_SHIFT(ip) 5
- #define UNIPERIF_CONFIG_MEM_FMT_MASK(ip) 0x1
- #define VALUE_UNIPERIF_CONFIG_MEM_FMT_16_0(ip) 0
- #define VALUE_UNIPERIF_CONFIG_MEM_FMT_16_16(ip) 1
- #define GET_UNIPERIF_CONFIG_MEM_FMT(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_MEM_FMT_SHIFT(ip), \
- UNIPERIF_CONFIG_MEM_FMT_MASK(ip))
- #define SET_UNIPERIF_CONFIG_MEM_FMT(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_MEM_FMT_SHIFT(ip), \
- UNIPERIF_CONFIG_MEM_FMT_MASK(ip), value)
- #define SET_UNIPERIF_CONFIG_MEM_FMT_16_0(ip) \
- SET_UNIPERIF_CONFIG_MEM_FMT(ip, \
- VALUE_UNIPERIF_CONFIG_MEM_FMT_16_0(ip))
- #define SET_UNIPERIF_CONFIG_MEM_FMT_16_16(ip) \
- SET_UNIPERIF_CONFIG_MEM_FMT(ip, \
- VALUE_UNIPERIF_CONFIG_MEM_FMT_16_16(ip))
- /* REPEAT_CHL_STS */
- #define UNIPERIF_CONFIG_REPEAT_CHL_STS_SHIFT(ip) 6
- #define UNIPERIF_CONFIG_REPEAT_CHL_STS_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_REPEAT_CHL_STS(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_REPEAT_CHL_STS_SHIFT(ip), \
- UNIPERIF_CONFIG_REPEAT_CHL_STS_MASK(ip))
- #define SET_UNIPERIF_CONFIG_REPEAT_CHL_STS_ENABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_REPEAT_CHL_STS_SHIFT(ip), \
- UNIPERIF_CONFIG_REPEAT_CHL_STS_MASK(ip), 0)
- #define SET_UNIPERIF_CONFIG_REPEAT_CHL_STS_DISABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_REPEAT_CHL_STS_SHIFT(ip), \
- UNIPERIF_CONFIG_REPEAT_CHL_STS_MASK(ip), 1)
- /* BACK_STALL_REQ */
- #define UNIPERIF_CONFIG_BACK_STALL_REQ_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 7 : -1)
- #define UNIPERIF_CONFIG_BACK_STALL_REQ_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_BACK_STALL_REQ(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_BACK_STALL_REQ_SHIFT(ip), \
- UNIPERIF_CONFIG_BACK_STALL_REQ_MASK(ip))
- #define SET_UNIPERIF_CONFIG_BACK_STALL_REQ_DISABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_BACK_STALL_REQ_SHIFT(ip), \
- UNIPERIF_CONFIG_BACK_STALL_REQ_MASK(ip), 0)
- #define SET_UNIPERIF_CONFIG_BACK_STALL_REQ_ENABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_BACK_STALL_REQ_SHIFT(ip), \
- UNIPERIF_CONFIG_BACK_STALL_REQ_MASK(ip), 1)
- /* FDMA_TRIGGER_LIMIT */
- #define UNIPERIF_CONFIG_DMA_TRIG_LIMIT_SHIFT(ip) 8
- #define UNIPERIF_CONFIG_DMA_TRIG_LIMIT_MASK(ip) 0x7F
- #define GET_UNIPERIF_CONFIG_DMA_TRIG_LIMIT(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_DMA_TRIG_LIMIT_SHIFT(ip), \
- UNIPERIF_CONFIG_DMA_TRIG_LIMIT_MASK(ip))
- #define SET_UNIPERIF_CONFIG_DMA_TRIG_LIMIT(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_DMA_TRIG_LIMIT_SHIFT(ip), \
- UNIPERIF_CONFIG_DMA_TRIG_LIMIT_MASK(ip), value)
- /* CHL_STS_UPDATE */
- #define UNIPERIF_CONFIG_CHL_STS_UPDATE_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 16 : -1)
- #define UNIPERIF_CONFIG_CHL_STS_UPDATE_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_CHL_STS_UPDATE(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_CHL_STS_UPDATE_SHIFT(ip), \
- UNIPERIF_CONFIG_CHL_STS_UPDATE_MASK(ip))
- #define SET_UNIPERIF_CONFIG_CHL_STS_UPDATE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_CHL_STS_UPDATE_SHIFT(ip), \
- UNIPERIF_CONFIG_CHL_STS_UPDATE_MASK(ip), 1)
- /* IDLE_MOD */
- #define UNIPERIF_CONFIG_IDLE_MOD_SHIFT(ip) 18
- #define UNIPERIF_CONFIG_IDLE_MOD_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_IDLE_MOD(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_IDLE_MOD_SHIFT(ip), \
- UNIPERIF_CONFIG_IDLE_MOD_MASK(ip))
- #define SET_UNIPERIF_CONFIG_IDLE_MOD_DISABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_IDLE_MOD_SHIFT(ip), \
- UNIPERIF_CONFIG_IDLE_MOD_MASK(ip), 0)
- #define SET_UNIPERIF_CONFIG_IDLE_MOD_ENABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_IDLE_MOD_SHIFT(ip), \
- UNIPERIF_CONFIG_IDLE_MOD_MASK(ip), 1)
- /* SUBFRAME_SELECTION */
- #define UNIPERIF_CONFIG_SUBFRAME_SEL_SHIFT(ip) 19
- #define UNIPERIF_CONFIG_SUBFRAME_SEL_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_SUBFRAME_SEL(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_SUBFRAME_SEL_SHIFT(ip), \
- UNIPERIF_CONFIG_SUBFRAME_SEL_MASK(ip))
- #define SET_UNIPERIF_CONFIG_SUBFRAME_SEL_SUBF1_SUBF0(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_SUBFRAME_SEL_SHIFT(ip), \
- UNIPERIF_CONFIG_SUBFRAME_SEL_MASK(ip), 1)
- #define SET_UNIPERIF_CONFIG_SUBFRAME_SEL_SUBF0_SUBF1(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_SUBFRAME_SEL_SHIFT(ip), \
- UNIPERIF_CONFIG_SUBFRAME_SEL_MASK(ip), 0)
- /* FULL_SW_CONTROL */
- #define UNIPERIF_CONFIG_SPDIF_SW_CTRL_SHIFT(ip) 20
- #define UNIPERIF_CONFIG_SPDIF_SW_CTRL_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_SPDIF_SW_CTRL(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_SPDIF_SW_CTRL_SHIFT(ip), \
- UNIPERIF_CONFIG_SPDIF_SW_CTRL_MASK(ip))
- #define SET_UNIPERIF_CONFIG_SPDIF_SW_CTRL_ENABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_SPDIF_SW_CTRL_SHIFT(ip), \
- UNIPERIF_CONFIG_SPDIF_SW_CTRL_MASK(ip), 1)
- #define SET_UNIPERIF_CONFIG_SPDIF_SW_CTRL_DISABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_SPDIF_SW_CTRL_SHIFT(ip), \
- UNIPERIF_CONFIG_SPDIF_SW_CTRL_MASK(ip), 0)
- /* MASTER_CLKEDGE */
- #define UNIPERIF_CONFIG_MSTR_CLKEDGE_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 24 : -1)
- #define UNIPERIF_CONFIG_MSTR_CLKEDGE_MASK(ip) 0x1
- #define GET_UNIPERIF_CONFIG_MSTR_CLKEDGE(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_MSTR_CLKEDGE_SHIFT(ip), \
- UNIPERIF_CONFIG_MSTR_CLKEDGE_MASK(ip))
- #define SET_UNIPERIF_CONFIG_MSTR_CLKEDGE_FALLING(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_MSTR_CLKEDGE_SHIFT(ip), \
- UNIPERIF_CONFIG_MSTR_CLKEDGE_MASK(ip), 1)
- #define SET_UNIPERIF_CONFIG_MSTR_CLKEDGE_RISING(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CONFIG_OFFSET(ip), \
- UNIPERIF_CONFIG_MSTR_CLKEDGE_SHIFT(ip), \
- UNIPERIF_CONFIG_MSTR_CLKEDGE_MASK(ip), 0)
- /*
- * UNIPERIF_CTRL reg
- */
- #define UNIPERIF_CTRL_OFFSET(ip) 0x0044
- #define GET_UNIPERIF_CTRL(ip) \
- readl_relaxed(ip->base + UNIPERIF_CTRL_OFFSET(ip))
- #define SET_UNIPERIF_CTRL(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_CTRL_OFFSET(ip))
- /* OPERATION */
- #define UNIPERIF_CTRL_OPERATION_SHIFT(ip) 0
- #define UNIPERIF_CTRL_OPERATION_MASK(ip) 0x7
- #define GET_UNIPERIF_CTRL_OPERATION(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_OPERATION_SHIFT(ip), \
- UNIPERIF_CTRL_OPERATION_MASK(ip))
- #define VALUE_UNIPERIF_CTRL_OPERATION_OFF(ip) 0
- #define SET_UNIPERIF_CTRL_OPERATION_OFF(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_OPERATION_SHIFT(ip), \
- UNIPERIF_CTRL_OPERATION_MASK(ip), \
- VALUE_UNIPERIF_CTRL_OPERATION_OFF(ip))
- #define VALUE_UNIPERIF_CTRL_OPERATION_MUTE_PCM_NULL(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 1 : -1)
- #define SET_UNIPERIF_CTRL_OPERATION_MUTE_PCM_NULL(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_OPERATION_SHIFT(ip), \
- UNIPERIF_CTRL_OPERATION_MASK(ip), \
- VALUE_UNIPERIF_CTRL_OPERATION_MUTE_PCM_NULL(ip))
- #define VALUE_UNIPERIF_CTRL_OPERATION_MUTE_PAUSE_BURST(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 2 : -1)
- #define SET_UNIPERIF_CTRL_OPERATION_MUTE_PAUSE_BURST(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_OPERATION_SHIFT(ip), \
- UNIPERIF_CTRL_OPERATION_MASK(ip), \
- VALUE_UNIPERIF_CTRL_OPERATION_MUTE_PAUSE_BURST(ip))
- #define VALUE_UNIPERIF_CTRL_OPERATION_PCM_DATA(ip) 3
- #define SET_UNIPERIF_CTRL_OPERATION_PCM_DATA(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_OPERATION_SHIFT(ip), \
- UNIPERIF_CTRL_OPERATION_MASK(ip), \
- VALUE_UNIPERIF_CTRL_OPERATION_PCM_DATA(ip))
- /* This is the same as above! */
- #define VALUE_UNIPERIF_CTRL_OPERATION_AUDIO_DATA(ip) 3
- #define SET_UNIPERIF_CTRL_OPERATION_AUDIO_DATA(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_OPERATION_SHIFT(ip), \
- UNIPERIF_CTRL_OPERATION_MASK(ip), \
- VALUE_UNIPERIF_CTRL_OPERATION_AUDIO_DATA(ip))
- #define VALUE_UNIPERIF_CTRL_OPERATION_ENC_DATA(ip) 4
- #define SET_UNIPERIF_CTRL_OPERATION_ENC_DATA(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_OPERATION_SHIFT(ip), \
- UNIPERIF_CTRL_OPERATION_MASK(ip), \
- VALUE_UNIPERIF_CTRL_OPERATION_ENC_DATA(ip))
- #define VALUE_UNIPERIF_CTRL_OPERATION_CD_DATA(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 5 : -1)
- #define SET_UNIPERIF_CTRL_OPERATION_CD_DATA(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_OPERATION_SHIFT(ip), \
- UNIPERIF_CTRL_OPERATION_MASK(ip), \
- VALUE_UNIPERIF_CTRL_OPERATION_CD_DATA(ip))
- #define VALUE_UNIPERIF_CTRL_OPERATION_STANDBY(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 7)
- #define SET_UNIPERIF_CTRL_OPERATION_STANDBY(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_OPERATION_SHIFT(ip), \
- UNIPERIF_CTRL_OPERATION_MASK(ip), \
- VALUE_UNIPERIF_CTRL_OPERATION_STANDBY(ip))
- /* EXIT_STBY_ON_EOBLOCK */
- #define UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 3)
- #define UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_MASK(ip) 0x1
- #define GET_UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_SHIFT(ip), \
- UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_MASK(ip))
- #define SET_UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_OFF(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_SHIFT(ip), \
- UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_MASK(ip), 0)
- #define SET_UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_ON(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_SHIFT(ip), \
- UNIPERIF_CTRL_EXIT_STBY_ON_EOBLOCK_MASK(ip), 1)
- /* ROUNDING */
- #define UNIPERIF_CTRL_ROUNDING_SHIFT(ip) 4
- #define UNIPERIF_CTRL_ROUNDING_MASK(ip) 0x1
- #define GET_UNIPERIF_CTRL_ROUNDING(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_ROUNDING_SHIFT(ip), \
- UNIPERIF_CTRL_ROUNDING_MASK(ip))
- #define SET_UNIPERIF_CTRL_ROUNDING_OFF(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_ROUNDING_SHIFT(ip), \
- UNIPERIF_CTRL_ROUNDING_MASK(ip), 0)
- #define SET_UNIPERIF_CTRL_ROUNDING_ON(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_ROUNDING_SHIFT(ip), \
- UNIPERIF_CTRL_ROUNDING_MASK(ip), 1)
- /* DIVIDER */
- #define UNIPERIF_CTRL_DIVIDER_SHIFT(ip) 5
- #define UNIPERIF_CTRL_DIVIDER_MASK(ip) 0xff
- #define GET_UNIPERIF_CTRL_DIVIDER(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_DIVIDER_SHIFT(ip), \
- UNIPERIF_CTRL_DIVIDER_MASK(ip))
- #define SET_UNIPERIF_CTRL_DIVIDER(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_DIVIDER_SHIFT(ip), \
- UNIPERIF_CTRL_DIVIDER_MASK(ip), value)
- /* BYTE_SWAP */
- #define UNIPERIF_CTRL_BYTE_SWP_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 13 : -1)
- #define UNIPERIF_CTRL_BYTE_SWP_MASK(ip) 0x1
- #define GET_UNIPERIF_CTRL_BYTE_SWP(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_BYTE_SWP_SHIFT(ip), \
- UNIPERIF_CTRL_BYTE_SWP_MASK(ip))
- #define SET_UNIPERIF_CTRL_BYTE_SWP_OFF(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_BYTE_SWP_SHIFT(ip), \
- UNIPERIF_CTRL_BYTE_SWP_MASK(ip), 0)
- #define SET_UNIPERIF_CTRL_BYTE_SWP_ON(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_BYTE_SWP_SHIFT(ip), \
- UNIPERIF_CTRL_BYTE_SWP_MASK(ip), 1)
- /* ZERO_STUFFING_HW_SW */
- #define UNIPERIF_CTRL_ZERO_STUFF_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 14 : -1)
- #define UNIPERIF_CTRL_ZERO_STUFF_MASK(ip) 0x1
- #define GET_UNIPERIF_CTRL_ZERO_STUFF(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_ZERO_STUFF_SHIFT(ip), \
- UNIPERIF_CTRL_ZERO_STUFF_MASK(ip))
- #define SET_UNIPERIF_CTRL_ZERO_STUFF_HW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_ZERO_STUFF_SHIFT(ip), \
- UNIPERIF_CTRL_ZERO_STUFF_MASK(ip), 1)
- #define SET_UNIPERIF_CTRL_ZERO_STUFF_SW(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_ZERO_STUFF_SHIFT(ip), \
- UNIPERIF_CTRL_ZERO_STUFF_MASK(ip), 0)
- /* SPDIF_LAT */
- #define UNIPERIF_CTRL_SPDIF_LAT_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 16 : -1)
- #define UNIPERIF_CTRL_SPDIF_LAT_MASK(ip) 0x1
- #define GET_UNIPERIF_CTRL_SPDIF_LAT(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_SPDIF_LAT_SHIFT(ip), \
- UNIPERIF_CTRL_SPDIF_LAT_MASK(ip))
- #define SET_UNIPERIF_CTRL_SPDIF_LAT_ON(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_SPDIF_LAT_SHIFT(ip), \
- UNIPERIF_CTRL_SPDIF_LAT_MASK(ip), 1)
- #define SET_UNIPERIF_CTRL_SPDIF_LAT_OFF(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_SPDIF_LAT_SHIFT(ip), \
- UNIPERIF_CTRL_SPDIF_LAT_MASK(ip), 0)
- /* EN_SPDIF_FORMATTING */
- #define UNIPERIF_CTRL_SPDIF_FMT_SHIFT(ip) 17
- #define UNIPERIF_CTRL_SPDIF_FMT_MASK(ip) 0x1
- #define GET_UNIPERIF_CTRL_SPDIF_FMT(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_SPDIF_FMT_SHIFT(ip), \
- UNIPERIF_CTRL_SPDIF_FMT_MASK(ip))
- #define SET_UNIPERIF_CTRL_SPDIF_FMT_ON(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_SPDIF_FMT_SHIFT(ip), \
- UNIPERIF_CTRL_SPDIF_FMT_MASK(ip), 1)
- #define SET_UNIPERIF_CTRL_SPDIF_FMT_OFF(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_SPDIF_FMT_SHIFT(ip), \
- UNIPERIF_CTRL_SPDIF_FMT_MASK(ip), 0)
- /* READER_OUT_SELECT */
- #define UNIPERIF_CTRL_READER_OUT_SEL_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 18 : -1)
- #define UNIPERIF_CTRL_READER_OUT_SEL_MASK(ip) 0x1
- #define GET_UNIPERIF_CTRL_READER_OUT_SEL(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_READER_OUT_SEL_SHIFT(ip), \
- UNIPERIF_CTRL_READER_OUT_SEL_MASK(ip))
- #define SET_UNIPERIF_CTRL_READER_OUT_SEL_IN_MEM(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_READER_OUT_SEL_SHIFT(ip), \
- UNIPERIF_CTRL_READER_OUT_SEL_MASK(ip), 0)
- #define SET_UNIPERIF_CTRL_READER_OUT_SEL_ON_I2S_LINE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_READER_OUT_SEL_SHIFT(ip), \
- UNIPERIF_CTRL_READER_OUT_SEL_MASK(ip), 1)
- /* UNDERFLOW_REC_WINDOW */
- #define UNIPERIF_CTRL_UNDERFLOW_REC_WINDOW_SHIFT(ip) 20
- #define UNIPERIF_CTRL_UNDERFLOW_REC_WINDOW_MASK(ip) 0xff
- #define GET_UNIPERIF_CTRL_UNDERFLOW_REC_WINDOW(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_UNDERFLOW_REC_WINDOW_SHIFT(ip), \
- UNIPERIF_CTRL_UNDERFLOW_REC_WINDOW_MASK(ip))
- #define SET_UNIPERIF_CTRL_UNDERFLOW_REC_WINDOW(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_CTRL_OFFSET(ip), \
- UNIPERIF_CTRL_UNDERFLOW_REC_WINDOW_SHIFT(ip), \
- UNIPERIF_CTRL_UNDERFLOW_REC_WINDOW_MASK(ip), value)
- /*
- * UNIPERIF_I2S_FMT a.k.a UNIPERIF_FORMAT reg
- */
- #define UNIPERIF_I2S_FMT_OFFSET(ip) 0x0048
- #define GET_UNIPERIF_I2S_FMT(ip) \
- readl_relaxed(ip->base + UNIPERIF_I2S_FMT_OFFSET(ip))
- #define SET_UNIPERIF_I2S_FMT(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_I2S_FMT_OFFSET(ip))
- /* NBIT */
- #define UNIPERIF_I2S_FMT_NBIT_SHIFT(ip) 0
- #define UNIPERIF_I2S_FMT_NBIT_MASK(ip) 0x1
- #define GET_UNIPERIF_I2S_FMT_NBIT(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_NBIT_SHIFT(ip), \
- UNIPERIF_I2S_FMT_NBIT_MASK(ip))
- #define SET_UNIPERIF_I2S_FMT_NBIT_32(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_NBIT_SHIFT(ip), \
- UNIPERIF_I2S_FMT_NBIT_MASK(ip), 0)
- #define SET_UNIPERIF_I2S_FMT_NBIT_16(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_NBIT_SHIFT(ip), \
- UNIPERIF_I2S_FMT_NBIT_MASK(ip), 1)
- /* DATA_SIZE */
- #define UNIPERIF_I2S_FMT_DATA_SIZE_SHIFT(ip) 1
- #define UNIPERIF_I2S_FMT_DATA_SIZE_MASK(ip) 0x7
- #define GET_UNIPERIF_I2S_FMT_DATA_SIZE(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_MASK(ip))
- #define SET_UNIPERIF_I2S_FMT_DATA_SIZE_16(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_MASK(ip), 0)
- #define SET_UNIPERIF_I2S_FMT_DATA_SIZE_18(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_MASK(ip), 1)
- #define SET_UNIPERIF_I2S_FMT_DATA_SIZE_20(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_MASK(ip), 2)
- #define SET_UNIPERIF_I2S_FMT_DATA_SIZE_24(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_MASK(ip), 3)
- #define SET_UNIPERIF_I2S_FMTL_DATA_SIZE_28(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_MASK(ip), 4)
- #define SET_UNIPERIF_I2S_FMT_DATA_SIZE_32(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_DATA_SIZE_MASK(ip), 5)
- /* LR_POL */
- #define UNIPERIF_I2S_FMT_LR_POL_SHIFT(ip) 4
- #define UNIPERIF_I2S_FMT_LR_POL_MASK(ip) 0x1
- #define VALUE_UNIPERIF_I2S_FMT_LR_POL_LOW(ip) 0x0
- #define VALUE_UNIPERIF_I2S_FMT_LR_POL_HIG(ip) 0x1
- #define GET_UNIPERIF_I2S_FMT_LR_POL(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_LR_POL_SHIFT(ip), \
- UNIPERIF_I2S_FMT_LR_POL_MASK(ip))
- #define SET_UNIPERIF_I2S_FMT_LR_POL(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_LR_POL_SHIFT(ip), \
- UNIPERIF_I2S_FMT_LR_POL_MASK(ip), value)
- #define SET_UNIPERIF_I2S_FMT_LR_POL_LOW(ip) \
- SET_UNIPERIF_I2S_FMT_LR_POL(ip, \
- VALUE_UNIPERIF_I2S_FMT_LR_POL_LOW(ip))
- #define SET_UNIPERIF_I2S_FMT_LR_POL_HIG(ip) \
- SET_UNIPERIF_I2S_FMT_LR_POL(ip, \
- VALUE_UNIPERIF_I2S_FMT_LR_POL_HIG(ip))
- /* SCLK_EDGE */
- #define UNIPERIF_I2S_FMT_SCLK_EDGE_SHIFT(ip) 5
- #define UNIPERIF_I2S_FMT_SCLK_EDGE_MASK(ip) 0x1
- #define GET_UNIPERIF_I2S_FMT_SCLK_EDGE(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_SCLK_EDGE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_SCLK_EDGE_MASK(ip))
- #define SET_UNIPERIF_I2S_FMT_SCLK_EDGE_RISING(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_SCLK_EDGE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_SCLK_EDGE_MASK(ip), 0)
- #define SET_UNIPERIF_I2S_FMT_SCLK_EDGE_FALLING(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_SCLK_EDGE_SHIFT(ip), \
- UNIPERIF_I2S_FMT_SCLK_EDGE_MASK(ip), 1)
- /* PADDING */
- #define UNIPERIF_I2S_FMT_PADDING_SHIFT(ip) 6
- #define UNIPERIF_I2S_FMT_PADDING_MASK(ip) 0x1
- #define UNIPERIF_I2S_FMT_PADDING_MASK(ip) 0x1
- #define VALUE_UNIPERIF_I2S_FMT_PADDING_I2S_MODE(ip) 0x0
- #define VALUE_UNIPERIF_I2S_FMT_PADDING_SONY_MODE(ip) 0x1
- #define GET_UNIPERIF_I2S_FMT_PADDING(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_PADDING_SHIFT(ip), \
- UNIPERIF_I2S_FMT_PADDING_MASK(ip))
- #define SET_UNIPERIF_I2S_FMT_PADDING(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_PADDING_SHIFT(ip), \
- UNIPERIF_I2S_FMT_PADDING_MASK(ip), value)
- #define SET_UNIPERIF_I2S_FMT_PADDING_I2S_MODE(ip) \
- SET_UNIPERIF_I2S_FMT_PADDING(ip, \
- VALUE_UNIPERIF_I2S_FMT_PADDING_I2S_MODE(ip))
- #define SET_UNIPERIF_I2S_FMT_PADDING_SONY_MODE(ip) \
- SET_UNIPERIF_I2S_FMT_PADDING(ip, \
- VALUE_UNIPERIF_I2S_FMT_PADDING_SONY_MODE(ip))
- /* ALIGN */
- #define UNIPERIF_I2S_FMT_ALIGN_SHIFT(ip) 7
- #define UNIPERIF_I2S_FMT_ALIGN_MASK(ip) 0x1
- #define GET_UNIPERIF_I2S_FMT_ALIGN(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_ALIGN_SHIFT(ip), \
- UNIPERIF_I2S_FMT_ALIGN_MASK(ip))
- #define SET_UNIPERIF_I2S_FMT_ALIGN_LEFT(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_ALIGN_SHIFT(ip), \
- UNIPERIF_I2S_FMT_ALIGN_MASK(ip), 0)
- #define SET_UNIPERIF_I2S_FMT_ALIGN_RIGHT(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_ALIGN_SHIFT(ip), \
- UNIPERIF_I2S_FMT_ALIGN_MASK(ip), 1)
- /* ORDER */
- #define UNIPERIF_I2S_FMT_ORDER_SHIFT(ip) 8
- #define UNIPERIF_I2S_FMT_ORDER_MASK(ip) 0x1
- #define GET_UNIPERIF_I2S_FMT_ORDER(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_ORDER_SHIFT(ip), \
- UNIPERIF_I2S_FMT_ORDER_MASK(ip))
- #define SET_UNIPERIF_I2S_FMT_ORDER_LSB(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_ORDER_SHIFT(ip), \
- UNIPERIF_I2S_FMT_ORDER_MASK(ip), 0)
- #define SET_UNIPERIF_I2S_FMT_ORDER_MSB(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_ORDER_SHIFT(ip), \
- UNIPERIF_I2S_FMT_ORDER_MASK(ip), 1)
- /* NUM_CH */
- #define UNIPERIF_I2S_FMT_NUM_CH_SHIFT(ip) 9
- #define UNIPERIF_I2S_FMT_NUM_CH_MASK(ip) 0x7
- #define GET_UNIPERIF_I2S_FMT_NUM_CH(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_NUM_CH_SHIFT(ip), \
- UNIPERIF_I2S_FMT_NUM_CH_MASK(ip))
- #define SET_UNIPERIF_I2S_FMT_NUM_CH(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_NUM_CH_SHIFT(ip), \
- UNIPERIF_I2S_FMT_NUM_CH_MASK(ip), value)
- /* NO_OF_SAMPLES_TO_READ */
- #define UNIPERIF_I2S_FMT_NO_OF_SAMPLES_TO_READ_SHIFT(ip) 12
- #define UNIPERIF_I2S_FMT_NO_OF_SAMPLES_TO_READ_MASK(ip) 0xfffff
- #define GET_UNIPERIF_I2S_FMT_NO_OF_SAMPLES_TO_READ(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_NO_OF_SAMPLES_TO_READ_SHIFT(ip), \
- UNIPERIF_I2S_FMT_NO_OF_SAMPLES_TO_READ_MASK(ip))
- #define SET_UNIPERIF_I2S_FMT_NO_OF_SAMPLES_TO_READ(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_I2S_FMT_OFFSET(ip), \
- UNIPERIF_I2S_FMT_NO_OF_SAMPLES_TO_READ_SHIFT(ip), \
- UNIPERIF_I2S_FMT_NO_OF_SAMPLES_TO_READ_MASK(ip), value)
- /*
- * UNIPERIF_BIT_CONTROL reg
- */
- #define UNIPERIF_BIT_CONTROL_OFFSET(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 0x004c)
- #define GET_UNIPERIF_BIT_CONTROL(ip) \
- readl_relaxed(ip->base + UNIPERIF_BIT_CONTROL_OFFSET(ip))
- #define SET_UNIPERIF_BIT_CONTROL(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_BIT_CONTROL_OFFSET(ip))
- /* CLR_UNDERFLOW_DURATION */
- #define UNIPERIF_BIT_CONTROL_CLR_UNDERFLOW_DURATION_SHIFT(ip) 0
- #define UNIPERIF_BIT_CONTROL_CLR_UNDERFLOW_DURATION_MASK(ip) 0x1
- #define GET_UNIPERIF_BIT_CONTROL_CLR_UNDERFLOW_DURATION(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_BIT_CONTROL_OFFSET(ip), \
- UNIPERIF_BIT_CONTROL_CLR_UNDERFLOW_DURATION_SHIFT(ip), \
- UNIPERIF_BIT_CONTROL_CLR_UNDERFLOW_DURATION_MASK(ip))
- #define SET_UNIPERIF_BIT_CONTROL_CLR_UNDERFLOW_DURATION(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_BIT_CONTROL_OFFSET(ip), \
- UNIPERIF_BIT_CONTROL_CLR_UNDERFLOW_DURATION_SHIFT(ip), \
- UNIPERIF_BIT_CONTROL_CLR_UNDERFLOW_DURATION_MASK(ip), 1)
- /* CHL_STS_UPDATE */
- #define UNIPERIF_BIT_CONTROL_CHL_STS_UPDATE_SHIFT(ip) 1
- #define UNIPERIF_BIT_CONTROL_CHL_STS_UPDATE_MASK(ip) 0x1
- #define GET_UNIPERIF_BIT_CONTROL_CHL_STS_UPDATE(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_BIT_CONTROL_OFFSET(ip), \
- UNIPERIF_BIT_CONTROL_CHL_STS_UPDATE_SHIFT(ip), \
- UNIPERIF_BIT_CONTROL_CHL_STS_UPDATE_MASK(ip))
- #define SET_UNIPERIF_BIT_CONTROL_CHL_STS_UPDATE(ip) \
- SET_UNIPERIF_BIT_REG(ip, \
- UNIPERIF_BIT_CONTROL_OFFSET(ip), \
- UNIPERIF_BIT_CONTROL_CHL_STS_UPDATE_SHIFT(ip), \
- UNIPERIF_BIT_CONTROL_CHL_STS_UPDATE_MASK(ip), 1)
- /*
- * UNIPERIF_STATUS_1 reg
- */
- #define UNIPERIF_STATUS_1_OFFSET(ip) 0x0050
- #define GET_UNIPERIF_STATUS_1(ip) \
- readl_relaxed(ip->base + UNIPERIF_STATUS_1_OFFSET(ip))
- #define SET_UNIPERIF_STATUS_1(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_STATUS_1_OFFSET(ip))
- /* UNDERFLOW_DURATION */
- #define UNIPERIF_STATUS_1_UNDERFLOW_DURATION_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 0)
- #define UNIPERIF_STATUS_1_UNDERFLOW_DURATION_MASK(ip) 0xff
- #define GET_UNIPERIF_STATUS_1_UNDERFLOW_DURATION(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_STATUS_1_OFFSET(ip), \
- UNIPERIF_STATUS_1_UNDERFLOW_DURATION_SHIFT(ip), \
- UNIPERIF_STATUS_1_UNDERFLOW_DURATION_MASK(ip))
- #define SET_UNIPERIF_STATUS_1_UNDERFLOW_DURATION(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_STATUS_1_OFFSET(ip), \
- UNIPERIF_STATUS_1_UNDERFLOW_DURATION_SHIFT(ip), \
- UNIPERIF_STATUS_1_UNDERFLOW_DURATION_MASK(ip), value)
- /*
- * UNIPERIF_CHANNEL_STA_REGN reg
- */
- #define UNIPERIF_CHANNEL_STA_REGN(ip, n) (0x0060 + (4 * n))
- #define GET_UNIPERIF_CHANNEL_STA_REGN(ip) \
- readl_relaxed(ip->base + UNIPERIF_CHANNEL_STA_REGN(ip, n))
- #define SET_UNIPERIF_CHANNEL_STA_REGN(ip, n, value) \
- writel_relaxed(value, ip->base + \
- UNIPERIF_CHANNEL_STA_REGN(ip, n))
- /*
- * UNIPERIF_USER_VALIDITY reg
- */
- #define UNIPERIF_USER_VALIDITY_OFFSET(ip) 0x0090
- #define GET_UNIPERIF_USER_VALIDITY(ip) \
- readl_relaxed(ip->base + UNIPERIF_USER_VALIDITY_OFFSET(ip))
- #define SET_UNIPERIF_USER_VALIDITY(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_USER_VALIDITY_OFFSET(ip))
- /* VALIDITY_LEFT_AND_RIGHT */
- #define UNIPERIF_USER_VALIDITY_VALIDITY_LR_SHIFT(ip) 0
- #define UNIPERIF_USER_VALIDITY_VALIDITY_LR_MASK(ip) 0x3
- #define GET_UNIPERIF_USER_VALIDITY_VALIDITY_LR(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_USER_VALIDITY_OFFSET(ip), \
- UNIPERIF_USER_VALIDITY_VALIDITY_LR_SHIFT(ip), \
- UNIPERIF_USER_VALIDITY_VALIDITY_LR_MASK(ip))
- #define SET_UNIPERIF_USER_VALIDITY_VALIDITY_LR(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_USER_VALIDITY_OFFSET(ip), \
- UNIPERIF_USER_VALIDITY_VALIDITY_LR_SHIFT(ip), \
- UNIPERIF_USER_VALIDITY_VALIDITY_LR_MASK(ip), \
- value ? 0x3 : 0)
- /*
- * UNIPERIF_DBG_STANDBY_LEFT_SP reg
- */
- #define UNIPERIF_DBG_STANDBY_LEFT_SP_OFFSET(ip) 0x0150
- #define UNIPERIF_DBG_STANDBY_LEFT_SP_SHIFT(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? -1 : 0)
- #define UNIPERIF_DBG_STANDBY_LEFT_SP_MASK(ip) \
- ((ip)->ver < SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0 ? 0 : 0xFFFFFF)
- #define GET_UNIPERIF_DBG_STANDBY_LEFT_SP(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_DBG_STANDBY_LEFT_SP_OFFSET(ip), \
- UNIPERIF_DBG_STANDBY_LEFT_SP_SHIFT(ip), \
- UNIPERIF_DBG_STANDBY_LEFT_SP_MASK(ip))
- #define SET_UNIPERIF_DBG_STANDBY_LEFT_SP(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_DBG_STANDBY_LEFT_SP_OFFSET(ip), \
- UNIPERIF_DBG_STANDBY_LEFT_SP_SHIFT(ip), \
- UNIPERIF_DBG_STANDBY_LEFT_SP_MASK(ip), value)
- /*
- * UNIPERIF_TDM_ENABLE
- */
- #define UNIPERIF_TDM_ENABLE_OFFSET(ip) 0x0118
- #define GET_UNIPERIF_TDM_ENABLE(ip) \
- readl_relaxed(ip->base + UNIPERIF_TDM_ENABLE_OFFSET(ip))
- #define SET_UNIPERIF_TDM_ENABLE(ip, value) \
- writel_relaxed(value, ip->base + UNIPERIF_TDM_ENABLE_OFFSET(ip))
- /* TDM_ENABLE */
- #define UNIPERIF_TDM_ENABLE_EN_TDM_SHIFT(ip) 0x0
- #define UNIPERIF_TDM_ENABLE_EN_TDM_MASK(ip) 0x1
- #define GET_UNIPERIF_TDM_ENABLE_EN_TDM(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_ENABLE_OFFSET(ip), \
- UNIPERIF_TDM_ENABLE_EN_TDM_SHIFT(ip), \
- UNIPERIF_TDM_ENABLE_EN_TDM_MASK(ip))
- #define SET_UNIPERIF_TDM_ENABLE_TDM_ENABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_ENABLE_OFFSET(ip), \
- UNIPERIF_TDM_ENABLE_EN_TDM_SHIFT(ip), \
- UNIPERIF_TDM_ENABLE_EN_TDM_MASK(ip), 1)
- #define SET_UNIPERIF_TDM_ENABLE_TDM_DISABLE(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_ENABLE_OFFSET(ip), \
- UNIPERIF_TDM_ENABLE_EN_TDM_SHIFT(ip), \
- UNIPERIF_TDM_ENABLE_EN_TDM_MASK(ip), 0)
- /*
- * UNIPERIF_TDM_FS_REF_FREQ
- */
- #define UNIPERIF_TDM_FS_REF_FREQ_OFFSET(ip) 0x011c
- #define GET_UNIPERIF_TDM_FS_REF_FREQ(ip) \
- readl_relaxed(ip->base + UNIPERIF_TDM_FS_REF_FREQ_OFFSET(ip))
- #define SET_UNIPERIF_TDM_FS_REF_FREQ(ip, value) \
- writel_relaxed(value, ip->base + \
- UNIPERIF_TDM_FS_REF_FREQ_OFFSET(ip))
- /* REF_FREQ */
- #define UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_SHIFT(ip) 0x0
- #define VALUE_UNIPERIF_TDM_FS_REF_FREQ_8KHZ(ip) 0
- #define VALUE_UNIPERIF_TDM_FS_REF_FREQ_16KHZ(ip) 1
- #define VALUE_UNIPERIF_TDM_FS_REF_FREQ_32KHZ(ip) 2
- #define VALUE_UNIPERIF_TDM_FS_REF_FREQ_48KHZ(ip) 3
- #define UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_MASK(ip) 0x3
- #define GET_UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_FS_REF_FREQ_OFFSET(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_SHIFT(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_MASK(ip))
- #define SET_UNIPERIF_TDM_FS_REF_FREQ_8KHZ(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_FS_REF_FREQ_OFFSET(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_SHIFT(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_MASK(ip), \
- VALUE_UNIPERIF_TDM_FS_REF_FREQ_8KHZ(ip))
- #define SET_UNIPERIF_TDM_FS_REF_FREQ_16KHZ(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_FS_REF_FREQ_OFFSET(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_SHIFT(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_MASK(ip), \
- VALUE_UNIPERIF_TDM_FS_REF_FREQ_16KHZ(ip))
- #define SET_UNIPERIF_TDM_FS_REF_FREQ_32KHZ(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_FS_REF_FREQ_OFFSET(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_SHIFT(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_MASK(ip), \
- VALUE_UNIPERIF_TDM_FS_REF_FREQ_32KHZ(ip))
- #define SET_UNIPERIF_TDM_FS_REF_FREQ_48KHZ(ip) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_FS_REF_FREQ_OFFSET(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_SHIFT(ip), \
- UNIPERIF_TDM_FS_REF_FREQ_REF_FREQ_MASK(ip), \
- VALUE_UNIPERIF_TDM_FS_REF_FREQ_48KHZ(ip))
- /*
- * UNIPERIF_TDM_FS_REF_DIV
- */
- #define UNIPERIF_TDM_FS_REF_DIV_OFFSET(ip) 0x0120
- #define GET_UNIPERIF_TDM_FS_REF_DIV(ip) \
- readl_relaxed(ip->base + UNIPERIF_TDM_FS_REF_DIV_OFFSET(ip))
- #define SET_UNIPERIF_TDM_FS_REF_DIV(ip, value) \
- writel_relaxed(value, ip->base + \
- UNIPERIF_TDM_FS_REF_DIV_OFFSET(ip))
- /* NUM_TIMESLOT */
- #define UNIPERIF_TDM_FS_REF_DIV_NUM_TIMESLOT_SHIFT(ip) 0x0
- #define UNIPERIF_TDM_FS_REF_DIV_NUM_TIMESLOT_MASK(ip) 0xff
- #define GET_UNIPERIF_TDM_FS_REF_DIV_NUM_TIMESLOT(ip) \
- GET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_FS_REF_DIV_OFFSET(ip), \
- UNIPERIF_TDM_FS_REF_DIV_NUM_TIMESLOT_SHIFT(ip), \
- UNIPERIF_TDM_FS_REF_DIV_NUM_TIMESLOT_MASK(ip))
- #define SET_UNIPERIF_TDM_FS_REF_DIV_NUM_TIMESLOT(ip, value) \
- SET_UNIPERIF_REG(ip, \
- UNIPERIF_TDM_FS_REF_DIV_OFFSET(ip), \
- UNIPERIF_TDM_FS_REF_DIV_NUM_TIMESLOT_SHIFT(ip), \
- UNIPERIF_TDM_FS_REF_DIV_NUM_TIMESLOT_MASK(ip), value)
- /*
- * UNIPERIF_TDM_WORD_POS_X_Y
- * 32 bits of UNIPERIF_TDM_WORD_POS_X_Y register shall be set in 1 shot
- */
- #define UNIPERIF_TDM_WORD_POS_1_2_OFFSET(ip) 0x013c
- #define UNIPERIF_TDM_WORD_POS_3_4_OFFSET(ip) 0x0140
- #define UNIPERIF_TDM_WORD_POS_5_6_OFFSET(ip) 0x0144
- #define UNIPERIF_TDM_WORD_POS_7_8_OFFSET(ip) 0x0148
- #define GET_UNIPERIF_TDM_WORD_POS(ip, words) \
- readl_relaxed(ip->base + UNIPERIF_TDM_WORD_POS_##words##_OFFSET(ip))
- #define SET_UNIPERIF_TDM_WORD_POS(ip, words, value) \
- writel_relaxed(value, ip->base + \
- UNIPERIF_TDM_WORD_POS_##words##_OFFSET(ip))
- /*
- * uniperipheral IP capabilities
- */
- #define UNIPERIF_FIFO_SIZE 70 /* FIFO is 70 cells deep */
- #define UNIPERIF_FIFO_FRAMES 4 /* FDMA trigger limit in frames */
- #define UNIPERIF_TYPE_IS_HDMI(p) \
- ((p)->type == SND_ST_UNIPERIF_TYPE_HDMI)
- #define UNIPERIF_TYPE_IS_PCM(p) \
- ((p)->type == SND_ST_UNIPERIF_TYPE_PCM)
- #define UNIPERIF_TYPE_IS_SPDIF(p) \
- ((p)->type == SND_ST_UNIPERIF_TYPE_SPDIF)
- #define UNIPERIF_TYPE_IS_IEC958(p) \
- (UNIPERIF_TYPE_IS_HDMI(p) || \
- UNIPERIF_TYPE_IS_SPDIF(p))
- #define UNIPERIF_TYPE_IS_TDM(p) \
- ((p)->type == SND_ST_UNIPERIF_TYPE_TDM)
- /*
- * Uniperipheral IP revisions
- */
- enum uniperif_version {
- SND_ST_UNIPERIF_VERSION_UNKNOWN,
- /* SASG1 (Orly), Newman */
- SND_ST_UNIPERIF_VERSION_C6AUD0_UNI_1_0,
- /* SASC1, SASG2 (Orly2) */
- SND_ST_UNIPERIF_VERSION_UNI_PLR_1_0,
- /* SASC1, SASG2 (Orly2), TELSS, Cannes */
- SND_ST_UNIPERIF_VERSION_UNI_RDR_1_0,
- /* TELSS (SASC1) */
- SND_ST_UNIPERIF_VERSION_TDM_PLR_1_0,
- /* Cannes/Monaco */
- SND_ST_UNIPERIF_VERSION_UNI_PLR_TOP_1_0
- };
- enum uniperif_type {
- SND_ST_UNIPERIF_TYPE_NONE = 0x00,
- SND_ST_UNIPERIF_TYPE_HDMI = 0x01,
- SND_ST_UNIPERIF_TYPE_PCM = 0x02,
- SND_ST_UNIPERIF_TYPE_SPDIF = 0x04,
- SND_ST_UNIPERIF_TYPE_TDM = 0x08
- };
- enum uniperif_state {
- UNIPERIF_STATE_STOPPED,
- UNIPERIF_STATE_STARTED,
- UNIPERIF_STATE_STANDBY,
- UNIPERIF_STATE_UNDERFLOW,
- UNIPERIF_STATE_OVERFLOW = UNIPERIF_STATE_UNDERFLOW,
- UNIPERIF_STATE_XRUN
- };
- enum uniperif_iec958_encoding_mode {
- UNIPERIF_IEC958_ENCODING_MODE_PCM,
- UNIPERIF_IEC958_ENCODING_MODE_ENCODED
- };
- enum uniperif_word_pos {
- WORD_1_2,
- WORD_3_4,
- WORD_5_6,
- WORD_7_8,
- WORD_MAX
- };
- struct uniperif_iec958_settings {
- enum uniperif_iec958_encoding_mode encoding_mode;
- struct snd_aes_iec958 iec958;
- };
- struct dai_tdm_slot {
- unsigned int mask;
- int slots;
- int slot_width;
- unsigned int avail_slots;
- };
- struct uniperif {
- /* System information */
- enum uniperif_type type;
- int underflow_enabled; /* Underflow recovery mode */
- struct device *dev;
- int id; /* instance value of the uniperipheral IP */
- int ver; /* IP version, used by register access macros */
- struct regmap_field *clk_sel;
- struct regmap_field *valid_sel;
- spinlock_t irq_lock; /* use to prevent race condition with IRQ */
- /* capabilities */
- const struct snd_pcm_hardware *hw;
- /* Resources */
- struct resource *mem_region;
- void __iomem *base;
- unsigned long fifo_phys_address;
- int irq;
- /* Clocks */
- struct clk *clk;
- int mclk;
- int clk_adj;
- /* Runtime data */
- enum uniperif_state state;
- struct snd_pcm_substream *substream;
- /* Specific to IEC958 player */
- struct uniperif_iec958_settings stream_settings;
- struct mutex ctrl_lock; /* For resource updated by stream and controls*/
- /*alsa ctrl*/
- struct snd_kcontrol_new *snd_ctrls;
- int num_ctrls;
- /* dai properties */
- unsigned int daifmt;
- struct dai_tdm_slot tdm_slot;
- /* DAI callbacks */
- const struct snd_soc_dai_ops *dai_ops;
- };
- struct sti_uniperiph_dai {
- int stream;
- struct uniperif *uni;
- struct snd_dmaengine_dai_dma_data dma_data;
- };
- struct sti_uniperiph_data {
- struct platform_device *pdev;
- struct snd_soc_dai_driver *dai;
- struct sti_uniperiph_dai dai_data;
- };
- static __maybe_unused const struct snd_pcm_hardware uni_tdm_hw = {
- .info = SNDRV_PCM_INFO_INTERLEAVED | SNDRV_PCM_INFO_BLOCK_TRANSFER |
- SNDRV_PCM_INFO_PAUSE | SNDRV_PCM_INFO_MMAP |
- SNDRV_PCM_INFO_MMAP_VALID,
- .formats = SNDRV_PCM_FMTBIT_S32_LE | SNDRV_PCM_FMTBIT_S16_LE,
- .rates = SNDRV_PCM_RATE_CONTINUOUS,
- .rate_min = 8000,
- .rate_max = 48000,
- .channels_min = 1,
- .channels_max = 32,
- .periods_min = 2,
- .periods_max = 10,
- .period_bytes_min = 128,
- .period_bytes_max = 64 * PAGE_SIZE,
- .buffer_bytes_max = 256 * PAGE_SIZE
- };
- /* uniperiph player*/
- int uni_player_init(struct platform_device *pdev,
- struct uniperif *player);
- int uni_player_resume(struct uniperif *player);
- /* uniperiph reader */
- int uni_reader_init(struct platform_device *pdev,
- struct uniperif *reader);
- /* common */
- int sti_uniperiph_dai_set_fmt(struct snd_soc_dai *dai,
- unsigned int fmt);
- int sti_uniperiph_dai_hw_params(struct snd_pcm_substream *substream,
- struct snd_pcm_hw_params *params,
- struct snd_soc_dai *dai);
- static inline int sti_uniperiph_get_user_frame_size(
- struct snd_pcm_runtime *runtime)
- {
- return (runtime->channels * snd_pcm_format_width(runtime->format) / 8);
- }
- static inline int sti_uniperiph_get_unip_tdm_frame_size(struct uniperif *uni)
- {
- return (uni->tdm_slot.slots * uni->tdm_slot.slot_width / 8);
- }
- int sti_uniperiph_reset(struct uniperif *uni);
- int sti_uniperiph_set_tdm_slot(struct snd_soc_dai *dai, unsigned int tx_mask,
- unsigned int rx_mask, int slots,
- int slot_width);
- int sti_uniperiph_get_tdm_word_pos(struct uniperif *uni,
- unsigned int *word_pos);
- int sti_uniperiph_fix_tdm_chan(struct snd_pcm_hw_params *params,
- struct snd_pcm_hw_rule *rule);
- int sti_uniperiph_fix_tdm_format(struct snd_pcm_hw_params *params,
- struct snd_pcm_hw_rule *rule);
- #endif
|