Commit 0830ada5 authored by Ian Abbott's avatar Ian Abbott Committed by Greg Kroah-Hartman

staging: comedi: s626: make CRA and CRB setup conversions more readable

Use the new macros defined in "s626.h" for constructing and decomposing
'CRA', 'CRB' and standardized encoder setup values to make the
conversions between standardized encoder setup values, and CRA/CRB
register values easier to follow.

There is some messing about with the 'IndxSrc' values which are 1-bit
wide in the standardized encoder setup, and 2-bit wide in the 'CRA' and
'CRB' register values.  This will be addressed by a later patch.
Signed-off-by: default avatarIan Abbott <abbotti@mev.co.uk>
Reviewed-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 2eaaccde
...@@ -656,7 +656,7 @@ static void s626_set_latch_source(struct comedi_device *dev, ...@@ -656,7 +656,7 @@ static void s626_set_latch_source(struct comedi_device *dev,
{ {
s626_debi_replace(dev, k->my_crb, s626_debi_replace(dev, k->my_crb,
~(S626_CRBMSK_INTCTRL | S626_CRBMSK_LATCHSRC), ~(S626_CRBMSK_INTCTRL | S626_CRBMSK_LATCHSRC),
value << S626_CRBBIT_LATCHSRC); S626_SET_CRB_LATCHSRC(value));
} }
/* /*
...@@ -678,14 +678,16 @@ static void s626_reset_cap_flags_a(struct comedi_device *dev, ...@@ -678,14 +678,16 @@ static void s626_reset_cap_flags_a(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
s626_debi_replace(dev, k->my_crb, ~S626_CRBMSK_INTCTRL, s626_debi_replace(dev, k->my_crb, ~S626_CRBMSK_INTCTRL,
S626_CRBMSK_INTRESETCMD | S626_CRBMSK_INTRESET_A); (S626_SET_CRB_INTRESETCMD(1) |
S626_SET_CRB_INTRESET_A(1)));
} }
static void s626_reset_cap_flags_b(struct comedi_device *dev, static void s626_reset_cap_flags_b(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
s626_debi_replace(dev, k->my_crb, ~S626_CRBMSK_INTCTRL, s626_debi_replace(dev, k->my_crb, ~S626_CRBMSK_INTCTRL,
S626_CRBMSK_INTRESETCMD | S626_CRBMSK_INTRESET_B); (S626_SET_CRB_INTRESETCMD(1) |
S626_SET_CRB_INTRESET_B(1)));
} }
/* /*
...@@ -698,6 +700,7 @@ static uint16_t s626_get_mode_a(struct comedi_device *dev, ...@@ -698,6 +700,7 @@ static uint16_t s626_get_mode_a(struct comedi_device *dev,
uint16_t cra; uint16_t cra;
uint16_t crb; uint16_t crb;
uint16_t setup; uint16_t setup;
unsigned cntsrc, clkmult, clkpol, encmode;
/* Fetch CRA and CRB register images. */ /* Fetch CRA and CRB register images. */
cra = s626_debi_read(dev, k->my_cra); cra = s626_debi_read(dev, k->my_cra);
...@@ -707,44 +710,41 @@ static uint16_t s626_get_mode_a(struct comedi_device *dev, ...@@ -707,44 +710,41 @@ static uint16_t s626_get_mode_a(struct comedi_device *dev,
* Populate the standardized counter setup bit fields. * Populate the standardized counter setup bit fields.
* Note: IndexSrc is restricted to ENC_X or IndxPol. * Note: IndexSrc is restricted to ENC_X or IndxPol.
*/ */
setup = (cra & S626_STDMSK_LOADSRC) | /* LoadSrc = LoadSrcA. */ setup =
((crb << (S626_STDBIT_LATCHSRC - S626_CRBBIT_LATCHSRC)) & /* LoadSrc = LoadSrcA. */
S626_STDMSK_LATCHSRC) | /* LatchSrc = LatchSrcA. */ S626_SET_STD_LOADSRC(S626_GET_CRA_LOADSRC_A(cra)) |
((cra << (S626_STDBIT_INTSRC - S626_CRABIT_INTSRC_A)) & /* LatchSrc = LatchSrcA. */
S626_STDMSK_INTSRC) | /* IntSrc = IntSrcA. */ S626_SET_STD_LATCHSRC(S626_GET_CRB_LATCHSRC(crb)) |
((cra << (S626_STDBIT_INDXSRC - (S626_CRABIT_INDXSRC_A + 1))) & /* IntSrc = IntSrcA. */
S626_STDMSK_INDXSRC) | /* IndxSrc = IndxSrcA<1>. */ S626_SET_STD_INTSRC(S626_GET_CRA_INTSRC_A(cra)) |
((cra >> (S626_CRABIT_INDXPOL_A - S626_STDBIT_INDXPOL)) & /* IndxSrc = IndxSrcA<1>. */
S626_STDMSK_INDXPOL) | /* IndxPol = IndxPolA. */ S626_SET_STD_INDXSRC(S626_GET_CRA_INDXSRC_A(cra) >> 1) |
((crb >> (S626_CRBBIT_CLKENAB_A - S626_STDBIT_CLKENAB)) & /* IndxPol = IndxPolA. */
S626_STDMSK_CLKENAB); /* ClkEnab = ClkEnabA. */ S626_SET_STD_INDXPOL(S626_GET_CRA_INDXPOL_A(cra)) |
/* ClkEnab = ClkEnabA. */
S626_SET_STD_CLKENAB(S626_GET_CRB_CLKENAB_A(crb));
/* Adjust mode-dependent parameters. */ /* Adjust mode-dependent parameters. */
if (cra & (S626_CNTSRC_SYSCLK << S626_CRABIT_CNTSRC_A)) { cntsrc = S626_GET_CRA_CNTSRC_A(cra);
if (cntsrc & S626_CNTSRC_SYSCLK) {
/* Timer mode (CntSrcA<1> == 1): */ /* Timer mode (CntSrcA<1> == 1): */
/* Indicate Timer mode. */ encmode = S626_ENCMODE_TIMER;
setup |= S626_ENCMODE_TIMER << S626_STDBIT_ENCMODE;
/* Set ClkPol to indicate count direction (CntSrcA<0>). */ /* Set ClkPol to indicate count direction (CntSrcA<0>). */
setup |= (cra << (S626_STDBIT_CLKPOL - S626_CRABIT_CNTSRC_A)) & clkpol = cntsrc & 1;
S626_STDMSK_CLKPOL;
/* ClkMult must be 1x in Timer mode. */ /* ClkMult must be 1x in Timer mode. */
setup |= S626_MULT_X1 << S626_STDBIT_CLKMULT; clkmult = S626_MULT_X1;
} else { } else {
/* Counter mode (CntSrcA<1> == 0): */ /* Counter mode (CntSrcA<1> == 0): */
/* Indicate Counter mode. */ encmode = S626_ENCMODE_COUNTER;
setup |= S626_ENCMODE_COUNTER << S626_STDBIT_ENCMODE;
/* Pass through ClkPol. */ /* Pass through ClkPol. */
setup |= (cra >> (S626_CRABIT_CLKPOL_A - S626_STDBIT_CLKPOL)) & clkpol = S626_GET_CRA_CLKPOL_A(cra);
S626_STDMSK_CLKPOL;
/* Force ClkMult to 1x if not legal, else pass through. */ /* Force ClkMult to 1x if not legal, else pass through. */
if ((cra & S626_CRAMSK_CLKMULT_A) == clkmult = S626_GET_CRA_CLKMULT_A(cra);
(S626_MULT_X0 << S626_CRABIT_CLKMULT_A)) if (clkmult == S626_MULT_X0)
setup |= S626_MULT_X1 << S626_STDBIT_CLKMULT; clkmult = S626_MULT_X1;
else
setup |= (cra >> (S626_CRABIT_CLKMULT_A -
S626_STDBIT_CLKMULT)) &
S626_STDMSK_CLKMULT;
} }
setup |= S626_SET_STD_ENCMODE(encmode) | S626_SET_STD_CLKMULT(clkmult) |
S626_SET_STD_CLKPOL(clkpol);
/* Return adjusted counter setup. */ /* Return adjusted counter setup. */
return setup; return setup;
...@@ -756,6 +756,7 @@ static uint16_t s626_get_mode_b(struct comedi_device *dev, ...@@ -756,6 +756,7 @@ static uint16_t s626_get_mode_b(struct comedi_device *dev,
uint16_t cra; uint16_t cra;
uint16_t crb; uint16_t crb;
uint16_t setup; uint16_t setup;
unsigned cntsrc, clkmult, clkpol, encmode;
/* Fetch CRA and CRB register images. */ /* Fetch CRA and CRB register images. */
cra = s626_debi_read(dev, k->my_cra); cra = s626_debi_read(dev, k->my_cra);
...@@ -765,50 +766,46 @@ static uint16_t s626_get_mode_b(struct comedi_device *dev, ...@@ -765,50 +766,46 @@ static uint16_t s626_get_mode_b(struct comedi_device *dev,
* Populate the standardized counter setup bit fields. * Populate the standardized counter setup bit fields.
* Note: IndexSrc is restricted to ENC_X or IndxPol. * Note: IndexSrc is restricted to ENC_X or IndxPol.
*/ */
setup = ((crb << (S626_STDBIT_INTSRC - S626_CRBBIT_INTSRC_B)) & setup =
S626_STDMSK_INTSRC) | /* IntSrc = IntSrcB. */ /* IntSrc = IntSrcB. */
((crb << (S626_STDBIT_LATCHSRC - S626_CRBBIT_LATCHSRC)) & S626_SET_STD_INTSRC(S626_GET_CRB_INTSRC_B(crb)) |
S626_STDMSK_LATCHSRC) | /* LatchSrc = LatchSrcB. */ /* LatchSrc = LatchSrcB. */
((crb << (S626_STDBIT_LOADSRC - S626_CRBBIT_LOADSRC_B)) & S626_SET_STD_LATCHSRC(S626_GET_CRB_LATCHSRC(crb)) |
S626_STDMSK_LOADSRC) | /* LoadSrc = LoadSrcB. */ /* LoadSrc = LoadSrcB. */
((crb << (S626_STDBIT_INDXPOL - S626_CRBBIT_INDXPOL_B)) & S626_SET_STD_LOADSRC(S626_GET_CRB_LOADSRC_B(crb)) |
S626_STDMSK_INDXPOL) | /* IndxPol = IndxPolB. */ /* IndxPol = IndxPolB. */
((crb >> (S626_CRBBIT_CLKENAB_B - S626_STDBIT_CLKENAB)) & S626_SET_STD_INDXPOL(S626_GET_CRB_INDXPOL_B(crb)) |
S626_STDMSK_CLKENAB) | /* ClkEnab = ClkEnabB. */ /* ClkEnab = ClkEnabB. */
((cra >> ((S626_CRABIT_INDXSRC_B + 1) - S626_STDBIT_INDXSRC)) & S626_SET_STD_CLKENAB(S626_GET_CRB_CLKENAB_B(crb)) |
S626_STDMSK_INDXSRC); /* IndxSrc = IndxSrcB<1>. */ /* IndxSrc = IndxSrcB<1>. */
S626_SET_STD_INDXSRC(S626_GET_CRA_INDXSRC_B(cra) >> 1);
/* Adjust mode-dependent parameters. */ /* Adjust mode-dependent parameters. */
if ((crb & S626_CRBMSK_CLKMULT_B) == cntsrc = S626_GET_CRA_CNTSRC_B(cra);
(S626_MULT_X0 << S626_CRBBIT_CLKMULT_B)) { clkmult = S626_GET_CRB_CLKMULT_B(crb);
if (clkmult == S626_MULT_X0) {
/* Extender mode (ClkMultB == S626_MULT_X0): */ /* Extender mode (ClkMultB == S626_MULT_X0): */
/* Indicate Extender mode. */ encmode = S626_ENCMODE_EXTENDER;
setup |= S626_ENCMODE_EXTENDER << S626_STDBIT_ENCMODE;
/* Indicate multiplier is 1x. */ /* Indicate multiplier is 1x. */
setup |= S626_MULT_X1 << S626_STDBIT_CLKMULT; clkmult = S626_MULT_X1;
/* Set ClkPol equal to Timer count direction (CntSrcB<0>). */ /* Set ClkPol equal to Timer count direction (CntSrcB<0>). */
setup |= (cra >> (S626_CRABIT_CNTSRC_B - S626_STDBIT_CLKPOL)) & clkpol = cntsrc & 1;
S626_STDMSK_CLKPOL; } else if (cntsrc & S626_CNTSRC_SYSCLK) {
} else if (cra & (S626_CNTSRC_SYSCLK << S626_CRABIT_CNTSRC_B)) {
/* Timer mode (CntSrcB<1> == 1): */ /* Timer mode (CntSrcB<1> == 1): */
/* Indicate Timer mode. */ encmode = S626_ENCMODE_TIMER;
setup |= S626_ENCMODE_TIMER << S626_STDBIT_ENCMODE;
/* Indicate multiplier is 1x. */ /* Indicate multiplier is 1x. */
setup |= S626_MULT_X1 << S626_STDBIT_CLKMULT; clkmult = S626_MULT_X1;
/* Set ClkPol equal to Timer count direction (CntSrcB<0>). */ /* Set ClkPol equal to Timer count direction (CntSrcB<0>). */
setup |= (cra >> (S626_CRABIT_CNTSRC_B - S626_STDBIT_CLKPOL)) & clkpol = cntsrc & 1;
S626_STDMSK_CLKPOL;
} else { } else {
/* If Counter mode (CntSrcB<1> == 0): */ /* If Counter mode (CntSrcB<1> == 0): */
/* Indicate Counter mode. */ encmode = S626_ENCMODE_COUNTER;
setup |= S626_ENCMODE_COUNTER << S626_STDBIT_ENCMODE;
/* Clock multiplier is passed through. */ /* Clock multiplier is passed through. */
setup |= (crb >> (S626_CRBBIT_CLKMULT_B -
S626_STDBIT_CLKMULT)) & S626_STDMSK_CLKMULT;
/* Clock polarity is passed through. */ /* Clock polarity is passed through. */
setup |= (crb << (S626_STDBIT_CLKPOL - S626_CRBBIT_CLKPOL_B)) & clkpol = S626_GET_CRB_CLKPOL_B(crb);
S626_STDMSK_CLKPOL;
} }
setup |= S626_SET_STD_ENCMODE(encmode) | S626_SET_STD_CLKMULT(clkmult) |
S626_SET_STD_CLKPOL(clkpol);
/* Return adjusted counter setup. */ /* Return adjusted counter setup. */
return setup; return setup;
...@@ -827,64 +824,58 @@ static void s626_set_mode_a(struct comedi_device *dev, ...@@ -827,64 +824,58 @@ static void s626_set_mode_a(struct comedi_device *dev,
struct s626_private *devpriv = dev->private; struct s626_private *devpriv = dev->private;
uint16_t cra; uint16_t cra;
uint16_t crb; uint16_t crb;
unsigned cntsrc, clkmult, clkpol;
/* Initialize CRA and CRB images. */ /* Initialize CRA and CRB images. */
/* Preload trigger is passed through. */ /* Preload trigger is passed through. */
cra = setup & S626_CRAMSK_LOADSRC_A; cra = S626_SET_CRA_LOADSRC_A(S626_GET_STD_LOADSRC(setup));
/* IndexSrc is restricted to ENC_X or IndxPol. */ /* IndexSrc is restricted to ENC_X or IndxPol. */
cra |= (setup & S626_STDMSK_INDXSRC) >> cra |= S626_SET_CRA_INDXSRC_A(S626_GET_STD_INDXSRC(setup) << 1);
(S626_STDBIT_INDXSRC - (S626_CRABIT_INDXSRC_A + 1));
/* Reset any pending CounterA event captures. */ /* Reset any pending CounterA event captures. */
crb = S626_CRBMSK_INTRESETCMD | S626_CRBMSK_INTRESET_A; crb = S626_SET_CRB_INTRESETCMD(1) | S626_SET_CRB_INTRESET_A(1);
/* Clock enable is passed through. */ /* Clock enable is passed through. */
crb |= (setup & S626_STDMSK_CLKENAB) << crb |= S626_SET_CRB_CLKENAB_A(S626_GET_STD_CLKENAB(setup));
(S626_CRBBIT_CLKENAB_A - S626_STDBIT_CLKENAB);
/* Force IntSrc to Disabled if disable_int_src is asserted. */ /* Force IntSrc to Disabled if disable_int_src is asserted. */
if (!disable_int_src) if (!disable_int_src)
cra |= (setup & S626_STDMSK_INTSRC) >> cra |= S626_SET_CRA_INTSRC_A(S626_GET_STD_INTSRC(setup));
(S626_STDBIT_INTSRC - S626_CRABIT_INTSRC_A);
/* Populate all mode-dependent attributes of CRA & CRB images. */ /* Populate all mode-dependent attributes of CRA & CRB images. */
switch ((setup & S626_STDMSK_ENCMODE) >> S626_STDBIT_ENCMODE) { clkpol = S626_GET_STD_CLKPOL(setup);
switch (S626_GET_STD_ENCMODE(setup)) {
case S626_ENCMODE_EXTENDER: /* Extender Mode: */ case S626_ENCMODE_EXTENDER: /* Extender Mode: */
/* Force to Timer mode (Extender valid only for B counters). */ /* Force to Timer mode (Extender valid only for B counters). */
/* Fall through to case S626_ENCMODE_TIMER: */ /* Fall through to case S626_ENCMODE_TIMER: */
case S626_ENCMODE_TIMER: /* Timer Mode: */ case S626_ENCMODE_TIMER: /* Timer Mode: */
/* CntSrcA<1> selects system clock */ /* CntSrcA<1> selects system clock */
cra |= S626_CNTSRC_SYSCLK << S626_CRABIT_CNTSRC_A; cntsrc = S626_CNTSRC_SYSCLK;
/* Count direction (CntSrcA<0>) obtained from ClkPol. */ /* Count direction (CntSrcA<0>) obtained from ClkPol. */
cra |= (setup & S626_STDMSK_CLKPOL) >> cntsrc |= clkpol;
(S626_STDBIT_CLKPOL - S626_CRABIT_CNTSRC_A);
/* ClkPolA behaves as always-on clock enable. */ /* ClkPolA behaves as always-on clock enable. */
cra |= 1 << S626_CRABIT_CLKPOL_A; clkpol = 1;
/* ClkMult must be 1x. */ /* ClkMult must be 1x. */
cra |= S626_MULT_X1 << S626_CRABIT_CLKMULT_A; clkmult = S626_MULT_X1;
break; break;
default: /* Counter Mode: */ default: /* Counter Mode: */
/* Select ENC_C and ENC_D as clock/direction inputs. */ /* Select ENC_C and ENC_D as clock/direction inputs. */
cra |= S626_CNTSRC_ENCODER << S626_CRABIT_CNTSRC_A; cntsrc = S626_CNTSRC_ENCODER;
/* Clock polarity is passed through. */ /* Clock polarity is passed through. */
cra |= (setup & S626_STDMSK_CLKPOL) <<
(S626_CRABIT_CLKPOL_A - S626_STDBIT_CLKPOL);
/* Force multiplier to x1 if not legal, else pass through. */ /* Force multiplier to x1 if not legal, else pass through. */
if ((setup & S626_STDMSK_CLKMULT) == clkmult = S626_GET_STD_CLKMULT(setup);
(S626_MULT_X0 << S626_STDBIT_CLKMULT)) if (clkmult == S626_MULT_X0)
cra |= S626_MULT_X1 << S626_CRABIT_CLKMULT_A; clkmult = S626_MULT_X1;
else
cra |= (setup & S626_STDMSK_CLKMULT) <<
(S626_CRABIT_CLKMULT_A - S626_STDBIT_CLKMULT);
break; break;
} }
cra |= S626_SET_CRA_CNTSRC_A(cntsrc) | S626_SET_CRA_CLKPOL_A(clkpol) |
S626_SET_CRA_CLKMULT_A(clkmult);
/* /*
* Force positive index polarity if IndxSrc is software-driven only, * Force positive index polarity if IndxSrc is software-driven only,
* otherwise pass it through. * otherwise pass it through.
*/ */
if (~setup & S626_STDMSK_INDXSRC) if (S626_GET_STD_INDXSRC(setup) == S626_INDXSRC_HARD)
cra |= (setup & S626_STDMSK_INDXPOL) << cra |= S626_SET_CRA_INDXPOL_A(S626_GET_STD_INDXPOL(setup));
(S626_CRABIT_INDXPOL_A - S626_STDBIT_INDXPOL);
/* /*
* If IntSrc has been forced to Disabled, update the MISC2 interrupt * If IntSrc has been forced to Disabled, update the MISC2 interrupt
...@@ -910,73 +901,65 @@ static void s626_set_mode_b(struct comedi_device *dev, ...@@ -910,73 +901,65 @@ static void s626_set_mode_b(struct comedi_device *dev,
struct s626_private *devpriv = dev->private; struct s626_private *devpriv = dev->private;
uint16_t cra; uint16_t cra;
uint16_t crb; uint16_t crb;
unsigned cntsrc, clkmult, clkpol;
/* Initialize CRA and CRB images. */ /* Initialize CRA and CRB images. */
/* IndexSrc field is restricted to ENC_X or IndxPol. */ /* IndexSrc field is restricted to ENC_X or IndxPol. */
cra = (setup & S626_STDMSK_INDXSRC) << cra = S626_SET_CRA_INDXSRC_B(S626_GET_STD_INDXSRC(setup) << 1);
(S626_CRABIT_INDXSRC_B + 1 - S626_STDBIT_INDXSRC);
/* Reset event captures and disable interrupts. */ /* Reset event captures and disable interrupts. */
crb = S626_CRBMSK_INTRESETCMD | S626_CRBMSK_INTRESET_B; crb = S626_SET_CRB_INTRESETCMD(1) | S626_SET_CRB_INTRESET_B(1);
/* Clock enable is passed through. */ /* Clock enable is passed through. */
crb |= (setup & S626_STDMSK_CLKENAB) << crb |= S626_SET_CRB_CLKENAB_B(S626_GET_STD_CLKENAB(setup));
(S626_CRBBIT_CLKENAB_B - S626_STDBIT_CLKENAB);
/* Preload trigger source is passed through. */ /* Preload trigger source is passed through. */
crb |= (setup & S626_STDMSK_LOADSRC) >> crb |= S626_SET_CRB_LOADSRC_B(S626_GET_STD_LOADSRC(setup));
(S626_STDBIT_LOADSRC - S626_CRBBIT_LOADSRC_B);
/* Force IntSrc to Disabled if disable_int_src is asserted. */ /* Force IntSrc to Disabled if disable_int_src is asserted. */
if (!disable_int_src) if (!disable_int_src)
crb |= (setup & S626_STDMSK_INTSRC) >> crb |= S626_SET_CRB_INTSRC_B(S626_GET_STD_INTSRC(setup));
(S626_STDBIT_INTSRC - S626_CRBBIT_INTSRC_B);
/* Populate all mode-dependent attributes of CRA & CRB images. */ /* Populate all mode-dependent attributes of CRA & CRB images. */
switch ((setup & S626_STDMSK_ENCMODE) >> S626_STDBIT_ENCMODE) { clkpol = S626_GET_STD_CLKPOL(setup);
switch (S626_GET_STD_ENCMODE(setup)) {
case S626_ENCMODE_TIMER: /* Timer Mode: */ case S626_ENCMODE_TIMER: /* Timer Mode: */
/* CntSrcB<1> selects system clock */ /* CntSrcB<1> selects system clock */
cra |= S626_CNTSRC_SYSCLK << S626_CRABIT_CNTSRC_B; cntsrc = S626_CNTSRC_SYSCLK;
/* with direction (CntSrcB<0>) obtained from ClkPol. */ /* with direction (CntSrcB<0>) obtained from ClkPol. */
cra |= (setup & S626_STDMSK_CLKPOL) << cntsrc |= clkpol;
(S626_CRABIT_CNTSRC_B - S626_STDBIT_CLKPOL);
/* ClkPolB behaves as always-on clock enable. */ /* ClkPolB behaves as always-on clock enable. */
crb |= 1 << S626_CRBBIT_CLKPOL_B; clkpol = 1;
/* ClkMultB must be 1x. */ /* ClkMultB must be 1x. */
crb |= S626_MULT_X1 << S626_CRBBIT_CLKMULT_B; clkmult = S626_MULT_X1;
break; break;
case S626_ENCMODE_EXTENDER: /* Extender Mode: */ case S626_ENCMODE_EXTENDER: /* Extender Mode: */
/* CntSrcB source is OverflowA (same as "timer") */ /* CntSrcB source is OverflowA (same as "timer") */
cra |= S626_CNTSRC_SYSCLK << S626_CRABIT_CNTSRC_B; cntsrc = S626_CNTSRC_SYSCLK;
/* with direction obtained from ClkPol. */ /* with direction obtained from ClkPol. */
cra |= (setup & S626_STDMSK_CLKPOL) << cntsrc |= clkpol;
(S626_CRABIT_CNTSRC_B - S626_STDBIT_CLKPOL);
/* ClkPolB controls IndexB -- always set to active. */ /* ClkPolB controls IndexB -- always set to active. */
crb |= 1 << S626_CRBBIT_CLKPOL_B; clkpol = 1;
/* ClkMultB selects OverflowA as the clock source. */ /* ClkMultB selects OverflowA as the clock source. */
crb |= S626_MULT_X0 << S626_CRBBIT_CLKMULT_B; clkmult = S626_MULT_X0;
break; break;
default: /* Counter Mode: */ default: /* Counter Mode: */
/* Select ENC_C and ENC_D as clock/direction inputs. */ /* Select ENC_C and ENC_D as clock/direction inputs. */
cra |= S626_CNTSRC_ENCODER << S626_CRABIT_CNTSRC_B; cntsrc = S626_CNTSRC_ENCODER;
/* ClkPol is passed through. */ /* ClkPol is passed through. */
crb |= (setup & S626_STDMSK_CLKPOL) >>
(S626_STDBIT_CLKPOL - S626_CRBBIT_CLKPOL_B);
/* Force ClkMult to x1 if not legal, otherwise pass through. */ /* Force ClkMult to x1 if not legal, otherwise pass through. */
if ((setup & S626_STDMSK_CLKMULT) == clkmult = S626_GET_STD_CLKMULT(setup);
(S626_MULT_X0 << S626_STDBIT_CLKMULT)) if (clkmult == S626_MULT_X0)
crb |= S626_MULT_X1 << S626_CRBBIT_CLKMULT_B; clkmult = S626_MULT_X1;
else
crb |= (setup & S626_STDMSK_CLKMULT) <<
(S626_CRBBIT_CLKMULT_B - S626_STDBIT_CLKMULT);
break; break;
} }
cra |= S626_SET_CRA_CNTSRC_B(cntsrc);
crb |= S626_SET_CRB_CLKPOL_B(clkpol) | S626_SET_CRB_CLKMULT_B(clkmult);
/* /*
* Force positive index polarity if IndxSrc is software-driven only, * Force positive index polarity if IndxSrc is software-driven only,
* otherwise pass it through. * otherwise pass it through.
*/ */
if (~setup & S626_STDMSK_INDXSRC) if (S626_GET_STD_INDXSRC(setup) == S626_INDXSRC_HARD)
crb |= (setup & S626_STDMSK_INDXPOL) >> crb |= S626_SET_CRB_INDXPOL_B(S626_GET_STD_INDXPOL(setup));
(S626_STDBIT_INDXPOL - S626_CRBBIT_INDXPOL_B);
/* /*
* If IntSrc has been forced to Disabled, update the MISC2 interrupt * If IntSrc has been forced to Disabled, update the MISC2 interrupt
...@@ -1003,7 +986,7 @@ static void s626_set_enable_a(struct comedi_device *dev, ...@@ -1003,7 +986,7 @@ static void s626_set_enable_a(struct comedi_device *dev,
{ {
s626_debi_replace(dev, k->my_crb, s626_debi_replace(dev, k->my_crb,
~(S626_CRBMSK_INTCTRL | S626_CRBMSK_CLKENAB_A), ~(S626_CRBMSK_INTCTRL | S626_CRBMSK_CLKENAB_A),
enab << S626_CRBBIT_CLKENAB_A); S626_SET_CRB_CLKENAB_A(enab));
} }
static void s626_set_enable_b(struct comedi_device *dev, static void s626_set_enable_b(struct comedi_device *dev,
...@@ -1011,26 +994,26 @@ static void s626_set_enable_b(struct comedi_device *dev, ...@@ -1011,26 +994,26 @@ static void s626_set_enable_b(struct comedi_device *dev,
{ {
s626_debi_replace(dev, k->my_crb, s626_debi_replace(dev, k->my_crb,
~(S626_CRBMSK_INTCTRL | S626_CRBMSK_CLKENAB_B), ~(S626_CRBMSK_INTCTRL | S626_CRBMSK_CLKENAB_B),
enab << S626_CRBBIT_CLKENAB_B); S626_SET_CRB_CLKENAB_B(enab));
} }
static uint16_t s626_get_enable_a(struct comedi_device *dev, static uint16_t s626_get_enable_a(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (s626_debi_read(dev, k->my_crb) >> S626_CRBBIT_CLKENAB_A) & 1; return S626_GET_CRB_CLKENAB_A(s626_debi_read(dev, k->my_crb));
} }
static uint16_t s626_get_enable_b(struct comedi_device *dev, static uint16_t s626_get_enable_b(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (s626_debi_read(dev, k->my_crb) >> S626_CRBBIT_CLKENAB_B) & 1; return S626_GET_CRB_CLKENAB_B(s626_debi_read(dev, k->my_crb));
} }
#ifdef unused #ifdef unused
static uint16_t s626_get_latch_source(struct comedi_device *dev, static uint16_t s626_get_latch_source(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (s626_debi_read(dev, k->my_crb) >> S626_CRBBIT_LATCHSRC) & 3; return S626_GET_CRB_LATCHSRC(s626_debi_read(dev, k->my_crb));
} }
#endif #endif
...@@ -1043,7 +1026,7 @@ static void s626_set_load_trig_a(struct comedi_device *dev, ...@@ -1043,7 +1026,7 @@ static void s626_set_load_trig_a(struct comedi_device *dev,
const struct s626_enc_info *k, uint16_t trig) const struct s626_enc_info *k, uint16_t trig)
{ {
s626_debi_replace(dev, k->my_cra, ~S626_CRAMSK_LOADSRC_A, s626_debi_replace(dev, k->my_cra, ~S626_CRAMSK_LOADSRC_A,
trig << S626_CRABIT_LOADSRC_A); S626_SET_CRA_LOADSRC_A(trig));
} }
static void s626_set_load_trig_b(struct comedi_device *dev, static void s626_set_load_trig_b(struct comedi_device *dev,
...@@ -1051,19 +1034,19 @@ static void s626_set_load_trig_b(struct comedi_device *dev, ...@@ -1051,19 +1034,19 @@ static void s626_set_load_trig_b(struct comedi_device *dev,
{ {
s626_debi_replace(dev, k->my_crb, s626_debi_replace(dev, k->my_crb,
~(S626_CRBMSK_LOADSRC_B | S626_CRBMSK_INTCTRL), ~(S626_CRBMSK_LOADSRC_B | S626_CRBMSK_INTCTRL),
trig << S626_CRBBIT_LOADSRC_B); S626_SET_CRB_LOADSRC_B(trig));
} }
static uint16_t s626_get_load_trig_a(struct comedi_device *dev, static uint16_t s626_get_load_trig_a(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (s626_debi_read(dev, k->my_cra) >> S626_CRABIT_LOADSRC_A) & 3; return S626_GET_CRA_LOADSRC_A(s626_debi_read(dev, k->my_cra));
} }
static uint16_t s626_get_load_trig_b(struct comedi_device *dev, static uint16_t s626_get_load_trig_b(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (s626_debi_read(dev, k->my_crb) >> S626_CRBBIT_LOADSRC_B) & 3; return S626_GET_CRB_LOADSRC_B(s626_debi_read(dev, k->my_crb));
} }
/* /*
...@@ -1079,11 +1062,12 @@ static void s626_set_int_src_a(struct comedi_device *dev, ...@@ -1079,11 +1062,12 @@ static void s626_set_int_src_a(struct comedi_device *dev,
/* Reset any pending counter overflow or index captures. */ /* Reset any pending counter overflow or index captures. */
s626_debi_replace(dev, k->my_crb, ~S626_CRBMSK_INTCTRL, s626_debi_replace(dev, k->my_crb, ~S626_CRBMSK_INTCTRL,
S626_CRBMSK_INTRESETCMD | S626_CRBMSK_INTRESET_A); (S626_SET_CRB_INTRESETCMD(1) |
S626_SET_CRB_INTRESET_A(1)));
/* Program counter interrupt source. */ /* Program counter interrupt source. */
s626_debi_replace(dev, k->my_cra, ~S626_CRAMSK_INTSRC_A, s626_debi_replace(dev, k->my_cra, ~S626_CRAMSK_INTSRC_A,
int_source << S626_CRABIT_INTSRC_A); S626_SET_CRA_INTSRC_A(int_source));
/* Update MISC2 interrupt enable mask. */ /* Update MISC2 interrupt enable mask. */
devpriv->counter_int_enabs = devpriv->counter_int_enabs =
...@@ -1102,13 +1086,12 @@ static void s626_set_int_src_b(struct comedi_device *dev, ...@@ -1102,13 +1086,12 @@ static void s626_set_int_src_b(struct comedi_device *dev,
crb = s626_debi_read(dev, k->my_crb) & ~S626_CRBMSK_INTCTRL; crb = s626_debi_read(dev, k->my_crb) & ~S626_CRBMSK_INTCTRL;
/* Reset any pending counter overflow or index captures. */ /* Reset any pending counter overflow or index captures. */
s626_debi_write(dev, k->my_crb, (crb | S626_CRBMSK_INTRESETCMD | s626_debi_write(dev, k->my_crb, (crb | S626_SET_CRB_INTRESETCMD(1) |
S626_CRBMSK_INTRESET_B)); S626_SET_CRB_INTRESET_B(1)));
/* Program counter interrupt source. */ /* Program counter interrupt source. */
s626_debi_write(dev, k->my_crb, s626_debi_write(dev, k->my_crb, ((crb & ~S626_CRBMSK_INTSRC_B) |
((crb & ~S626_CRBMSK_INTSRC_B) | S626_SET_CRB_INTSRC_B(int_source)));
(int_source << S626_CRBBIT_INTSRC_B)));
/* Update MISC2 interrupt enable mask. */ /* Update MISC2 interrupt enable mask. */
devpriv->counter_int_enabs = devpriv->counter_int_enabs =
...@@ -1119,13 +1102,13 @@ static void s626_set_int_src_b(struct comedi_device *dev, ...@@ -1119,13 +1102,13 @@ static void s626_set_int_src_b(struct comedi_device *dev,
static uint16_t s626_get_int_src_a(struct comedi_device *dev, static uint16_t s626_get_int_src_a(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (s626_debi_read(dev, k->my_cra) >> S626_CRABIT_INTSRC_A) & 3; return S626_GET_CRA_INTSRC_A(s626_debi_read(dev, k->my_cra));
} }
static uint16_t s626_get_int_src_b(struct comedi_device *dev, static uint16_t s626_get_int_src_b(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (s626_debi_read(dev, k->my_crb) >> S626_CRBBIT_INTSRC_B) & 3; return S626_GET_CRB_INTSRC_B(s626_debi_read(dev, k->my_crb));
} }
#ifdef unused #ifdef unused
...@@ -1136,13 +1119,13 @@ static void s626_set_clk_mult(struct comedi_device *dev, ...@@ -1136,13 +1119,13 @@ static void s626_set_clk_mult(struct comedi_device *dev,
const struct s626_enc_info *k, uint16_t value) const struct s626_enc_info *k, uint16_t value)
{ {
k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_CLKMULT) | k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_CLKMULT) |
(value << S626_STDBIT_CLKMULT)), false); S626_SET_STD_CLKMULT(value)), false);
} }
static uint16_t s626_get_clk_mult(struct comedi_device *dev, static uint16_t s626_get_clk_mult(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (k->get_mode(dev, k) >> S626_STDBIT_CLKMULT) & 3; return S626_GET_STD_CLKMULT(k->get_mode(dev, k));
} }
/* /*
...@@ -1152,13 +1135,13 @@ static void s626_set_clk_pol(struct comedi_device *dev, ...@@ -1152,13 +1135,13 @@ static void s626_set_clk_pol(struct comedi_device *dev,
const struct s626_enc_info *k, uint16_t value) const struct s626_enc_info *k, uint16_t value)
{ {
k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_CLKPOL) | k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_CLKPOL) |
(value << S626_STDBIT_CLKPOL)), false); S626_SET_STD_CLKPOL(value)), false);
} }
static uint16_t s626_get_clk_pol(struct comedi_device *dev, static uint16_t s626_get_clk_pol(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (k->get_mode(dev, k) >> S626_STDBIT_CLKPOL) & 1; return S626_GET_STD_CLKPOL(k->get_mode(dev, k));
} }
/* /*
...@@ -1168,13 +1151,13 @@ static void s626_set_enc_mode(struct comedi_device *dev, ...@@ -1168,13 +1151,13 @@ static void s626_set_enc_mode(struct comedi_device *dev,
const struct s626_enc_info *k, uint16_t value) const struct s626_enc_info *k, uint16_t value)
{ {
k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_ENCMODE) | k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_ENCMODE) |
(value << S626_STDBIT_ENCMODE)), false); S626_SET_STD_ENCMODE(value)), false);
} }
static uint16_t s626_get_enc_mode(struct comedi_device *dev, static uint16_t s626_get_enc_mode(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (k->get_mode(dev, k) >> S626_STDBIT_ENCMODE) & 3; return S626_GET_STD_ENCMODE(k->get_mode(dev, k));
} }
/* /*
...@@ -1184,13 +1167,13 @@ static void s626_set_index_pol(struct comedi_device *dev, ...@@ -1184,13 +1167,13 @@ static void s626_set_index_pol(struct comedi_device *dev,
const struct s626_enc_info *k, uint16_t value) const struct s626_enc_info *k, uint16_t value)
{ {
k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_INDXPOL) | k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_INDXPOL) |
((value != 0) << S626_STDBIT_INDXPOL)), false); S626_SET_STD_INDXPOL(value != 0)), false);
} }
static uint16_t s626_get_index_pol(struct comedi_device *dev, static uint16_t s626_get_index_pol(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (k->get_mode(dev, k) >> S626_STDBIT_INDXPOL) & 1; return S626_GET_STD_INDXPOL(k->get_mode(dev, k));
} }
/* /*
...@@ -1200,13 +1183,13 @@ static void s626_set_index_src(struct comedi_device *dev, ...@@ -1200,13 +1183,13 @@ static void s626_set_index_src(struct comedi_device *dev,
const struct s626_enc_info *k, uint16_t value) const struct s626_enc_info *k, uint16_t value)
{ {
k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_INDXSRC) | k->set_mode(dev, k, ((k->get_mode(dev, k) & ~S626_STDMSK_INDXSRC) |
((value != 0) << S626_STDBIT_INDXSRC)), false); S626_SET_STD_INDXSRC(value != 0)), false);
} }
static uint16_t s626_get_index_src(struct comedi_device *dev, static uint16_t s626_get_index_src(struct comedi_device *dev,
const struct s626_enc_info *k) const struct s626_enc_info *k)
{ {
return (k->get_mode(dev, k) >> S626_STDBIT_INDXSRC) & 1; return S626_GET_STD_INDXSRC(k->get_mode(dev, k));
} }
#endif #endif
...@@ -2031,16 +2014,17 @@ static void s626_timer_load(struct comedi_device *dev, ...@@ -2031,16 +2014,17 @@ static void s626_timer_load(struct comedi_device *dev,
{ {
uint16_t setup = uint16_t setup =
/* Preload upon index. */ /* Preload upon index. */
(S626_LOADSRC_INDX << S626_BF_LOADSRC) | S626_SET_STD_LOADSRC(S626_LOADSRC_INDX) |
/* Disable hardware index. */ /* Disable hardware index. */
(S626_INDXSRC_SOFT << S626_BF_INDXSRC) | S626_SET_STD_INDXSRC(S626_INDXSRC_SOFT) |
/* Operating mode is Timer. */ /* Operating mode is Timer. */
(S626_ENCMODE_TIMER << S626_BF_ENCMODE) | S626_SET_STD_ENCMODE(S626_ENCMODE_TIMER) |
/* Count direction is Down. */ /* Count direction is Down. */
(S626_CNTDIR_DOWN << S626_BF_CLKPOL) | S626_SET_STD_CLKPOL(S626_CNTDIR_DOWN) |
/* Clock multiplier is 1x. */ /* Clock multiplier is 1x. */
(S626_CLKMULT_1X << S626_BF_CLKMULT) | S626_SET_STD_CLKMULT(S626_CLKMULT_1X) |
(S626_CLKENAB_INDEX << S626_BF_CLKENAB); /* Enabled by index */
S626_SET_STD_CLKENAB(S626_CLKENAB_INDEX);
uint16_t value_latchsrc = S626_LATCHSRC_A_INDXA; uint16_t value_latchsrc = S626_LATCHSRC_A_INDXA;
/* uint16_t enab = S626_CLKENAB_ALWAYS; */ /* uint16_t enab = S626_CLKENAB_ALWAYS; */
...@@ -2423,16 +2407,17 @@ static int s626_enc_insn_config(struct comedi_device *dev, ...@@ -2423,16 +2407,17 @@ static int s626_enc_insn_config(struct comedi_device *dev,
{ {
uint16_t setup = uint16_t setup =
/* Preload upon index. */ /* Preload upon index. */
(S626_LOADSRC_INDX << S626_BF_LOADSRC) | S626_SET_STD_LOADSRC(S626_LOADSRC_INDX) |
/* Disable hardware index. */ /* Disable hardware index. */
(S626_INDXSRC_SOFT << S626_BF_INDXSRC) | S626_SET_STD_INDXSRC(S626_INDXSRC_SOFT) |
/* Operating mode is Counter. */ /* Operating mode is Counter. */
(S626_ENCMODE_COUNTER << S626_BF_ENCMODE) | S626_SET_STD_ENCMODE(S626_ENCMODE_COUNTER) |
/* Active high clock. */ /* Active high clock. */
(S626_CLKPOL_POS << S626_BF_CLKPOL) | S626_SET_STD_CLKPOL(S626_CLKPOL_POS) |
/* Clock multiplier is 1x. */ /* Clock multiplier is 1x. */
(S626_CLKMULT_1X << S626_BF_CLKMULT) | S626_SET_STD_CLKMULT(S626_CLKMULT_1X) |
(S626_CLKENAB_INDEX << S626_BF_CLKENAB); /* Enabled by index */
S626_SET_STD_CLKENAB(S626_CLKENAB_INDEX);
/* uint16_t disable_int_src = true; */ /* uint16_t disable_int_src = true; */
/* uint32_t Preloadvalue; //Counter initial value */ /* uint32_t Preloadvalue; //Counter initial value */
uint16_t value_latchsrc = S626_LATCHSRC_AB_READ; uint16_t value_latchsrc = S626_LATCHSRC_AB_READ;
...@@ -2519,17 +2504,17 @@ static void s626_counters_init(struct comedi_device *dev) ...@@ -2519,17 +2504,17 @@ static void s626_counters_init(struct comedi_device *dev)
const struct s626_enc_info *k; const struct s626_enc_info *k;
uint16_t setup = uint16_t setup =
/* Preload upon index. */ /* Preload upon index. */
(S626_LOADSRC_INDX << S626_BF_LOADSRC) | S626_SET_STD_LOADSRC(S626_LOADSRC_INDX) |
/* Disable hardware index. */ /* Disable hardware index. */
(S626_INDXSRC_SOFT << S626_BF_INDXSRC) | S626_SET_STD_INDXSRC(S626_INDXSRC_SOFT) |
/* Operating mode is counter. */ /* Operating mode is counter. */
(S626_ENCMODE_COUNTER << S626_BF_ENCMODE) | S626_SET_STD_ENCMODE(S626_ENCMODE_COUNTER) |
/* Active high clock. */ /* Active high clock. */
(S626_CLKPOL_POS << S626_BF_CLKPOL) | S626_SET_STD_CLKPOL(S626_CLKPOL_POS) |
/* Clock multiplier is 1x. */ /* Clock multiplier is 1x. */
(S626_CLKMULT_1X << S626_BF_CLKMULT) | S626_SET_STD_CLKMULT(S626_CLKMULT_1X) |
/* Enabled by index */ /* Enabled by index */
(S626_CLKENAB_INDEX << S626_BF_CLKENAB); S626_SET_STD_CLKENAB(S626_CLKENAB_INDEX);
/* /*
* Disable all counter interrupts and clear any captured counter events. * Disable all counter interrupts and clear any captured counter events.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment