Commit fca7c1d7 authored by H Hartley Sweeten's avatar H Hartley Sweeten Committed by Greg Kroah-Hartman

staging: comedi: ni_tio: use a local var for the 'counter_index'

Use a local variable for the 'counter->counter_index' to help shorten the
long lines and ugly line breaks.
Signed-off-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
Reviewed-by: default avatarIan Abbott <abbotti@mev.co.uk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 5382bfb9
...@@ -362,74 +362,64 @@ static int ni_tio_second_gate_registers_present(const struct ni_gpct_device ...@@ -362,74 +362,64 @@ static int ni_tio_second_gate_registers_present(const struct ni_gpct_device
static void ni_tio_reset_count_and_disarm(struct ni_gpct *counter) static void ni_tio_reset_count_and_disarm(struct ni_gpct *counter)
{ {
write_register(counter, Gi_Reset_Bit(counter->counter_index), unsigned cidx = counter->counter_index;
NITIO_RESET_REG(counter->counter_index));
write_register(counter, Gi_Reset_Bit(cidx), NITIO_RESET_REG(cidx));
} }
void ni_tio_init_counter(struct ni_gpct *counter) void ni_tio_init_counter(struct ni_gpct *counter)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
unsigned cidx = counter->counter_index;
ni_tio_reset_count_and_disarm(counter); ni_tio_reset_count_and_disarm(counter);
/* initialize counter registers */ /* initialize counter registers */
counter_dev->regs[NITIO_AUTO_INC_REG(counter->counter_index)] = counter_dev->regs[NITIO_AUTO_INC_REG(cidx)] = 0x0;
0x0; write_register(counter, counter_dev->regs[NITIO_AUTO_INC_REG(cidx)],
write_register(counter, NITIO_AUTO_INC_REG(cidx));
counter_dev->
regs[NITIO_AUTO_INC_REG(counter->counter_index)], ni_tio_set_bits(counter, NITIO_CMD_REG(cidx),
NITIO_AUTO_INC_REG(counter->counter_index));
ni_tio_set_bits(counter, NITIO_CMD_REG(counter->counter_index),
~0, Gi_Synchronize_Gate_Bit); ~0, Gi_Synchronize_Gate_Bit);
ni_tio_set_bits(counter, NITIO_MODE_REG(counter->counter_index), ~0,
0); ni_tio_set_bits(counter, NITIO_MODE_REG(cidx), ~0, 0);
counter_dev->regs[NITIO_LOADA_REG(counter->counter_index)] = 0x0;
write_register(counter, counter_dev->regs[NITIO_LOADA_REG(cidx)] = 0x0;
counter_dev-> write_register(counter, counter_dev->regs[NITIO_LOADA_REG(cidx)],
regs[NITIO_LOADA_REG(counter->counter_index)], NITIO_LOADA_REG(cidx));
NITIO_LOADA_REG(counter->counter_index));
counter_dev->regs[NITIO_LOADB_REG(counter->counter_index)] = 0x0; counter_dev->regs[NITIO_LOADB_REG(cidx)] = 0x0;
write_register(counter, write_register(counter, counter_dev->regs[NITIO_LOADB_REG(cidx)],
counter_dev-> NITIO_LOADB_REG(cidx));
regs[NITIO_LOADB_REG(counter->counter_index)],
NITIO_LOADB_REG(counter->counter_index)); ni_tio_set_bits(counter, NITIO_INPUT_SEL_REG(cidx), ~0, 0);
ni_tio_set_bits(counter,
NITIO_INPUT_SEL_REG(counter->counter_index), ~0, if (ni_tio_counting_mode_registers_present(counter_dev))
0); ni_tio_set_bits(counter, NITIO_CNT_MODE_REG(cidx), ~0, 0);
if (ni_tio_counting_mode_registers_present(counter_dev)) {
ni_tio_set_bits(counter,
NITIO_CNT_MODE_REG(counter->
counter_index), ~0,
0);
}
if (ni_tio_second_gate_registers_present(counter_dev)) { if (ni_tio_second_gate_registers_present(counter_dev)) {
counter_dev-> counter_dev->regs[NITIO_GATE2_REG(cidx)] = 0x0;
regs[NITIO_GATE2_REG(counter->counter_index)] =
0x0;
write_register(counter, write_register(counter,
counter_dev-> counter_dev->regs[NITIO_GATE2_REG(cidx)],
regs[NITIO_GATE2_REG NITIO_GATE2_REG(cidx));
(counter->counter_index)],
NITIO_GATE2_REG(counter->
counter_index));
} }
ni_tio_set_bits(counter,
NITIO_DMA_CFG_REG(counter->counter_index), ~0, ni_tio_set_bits(counter, NITIO_DMA_CFG_REG(cidx), ~0, 0x0);
0x0);
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_INT_ENA_REG(cidx), ~0, 0x0);
NITIO_INT_ENA_REG(counter->counter_index),
~0, 0x0);
} }
EXPORT_SYMBOL_GPL(ni_tio_init_counter); EXPORT_SYMBOL_GPL(ni_tio_init_counter);
static unsigned int ni_tio_counter_status(struct ni_gpct *counter) static unsigned int ni_tio_counter_status(struct ni_gpct *counter)
{ {
unsigned int status = 0; unsigned cidx = counter->counter_index;
const unsigned bits = read_register(counter, const unsigned bits = read_register(counter,
NITIO_SHARED_STATUS_REG(counter-> NITIO_SHARED_STATUS_REG(cidx));
counter_index)); unsigned int status = 0;
if (bits & Gi_Armed_Bit(counter->counter_index)) {
if (bits & Gi_Armed_Bit(cidx)) {
status |= COMEDI_COUNTER_ARMED; status |= COMEDI_COUNTER_ARMED;
if (bits & Gi_Counting_Bit(counter->counter_index)) if (bits & Gi_Counting_Bit(cidx))
status |= COMEDI_COUNTER_COUNTING; status |= COMEDI_COUNTER_COUNTING;
} }
return status; return status;
...@@ -438,8 +428,8 @@ static unsigned int ni_tio_counter_status(struct ni_gpct *counter) ...@@ -438,8 +428,8 @@ static unsigned int ni_tio_counter_status(struct ni_gpct *counter)
static void ni_tio_set_sync_mode(struct ni_gpct *counter, int force_alt_sync) static void ni_tio_set_sync_mode(struct ni_gpct *counter, int force_alt_sync)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned counting_mode_reg = unsigned cidx = counter->counter_index;
NITIO_CNT_MODE_REG(counter->counter_index); const unsigned counting_mode_reg = NITIO_CNT_MODE_REG(cidx);
static const uint64_t min_normal_sync_period_ps = 25000; static const uint64_t min_normal_sync_period_ps = 25000;
const uint64_t clock_period_ps = ni_tio_clock_period_ps(counter, const uint64_t clock_period_ps = ni_tio_clock_period_ps(counter,
ni_tio_generic_clock_src_select ni_tio_generic_clock_src_select
...@@ -476,6 +466,7 @@ static void ni_tio_set_sync_mode(struct ni_gpct *counter, int force_alt_sync) ...@@ -476,6 +466,7 @@ static void ni_tio_set_sync_mode(struct ni_gpct *counter, int force_alt_sync)
static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode) static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
unsigned cidx = counter->counter_index;
unsigned mode_reg_mask; unsigned mode_reg_mask;
unsigned mode_reg_values; unsigned mode_reg_values;
unsigned input_select_bits = 0; unsigned input_select_bits = 0;
...@@ -502,7 +493,7 @@ static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode) ...@@ -502,7 +493,7 @@ static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode)
default: default:
break; break;
} }
ni_tio_set_bits(counter, NITIO_MODE_REG(counter->counter_index), ni_tio_set_bits(counter, NITIO_MODE_REG(cidx),
mode_reg_mask, mode_reg_values); mode_reg_mask, mode_reg_values);
if (ni_tio_counting_mode_registers_present(counter_dev)) { if (ni_tio_counting_mode_registers_present(counter_dev)) {
...@@ -515,15 +506,13 @@ static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode) ...@@ -515,15 +506,13 @@ static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode)
Gi_Index_Phase_Bitshift) & Gi_Index_Phase_Mask; Gi_Index_Phase_Bitshift) & Gi_Index_Phase_Mask;
if (mode & NI_GPCT_INDEX_ENABLE_BIT) if (mode & NI_GPCT_INDEX_ENABLE_BIT)
counting_mode_bits |= Gi_Index_Mode_Bit; counting_mode_bits |= Gi_Index_Mode_Bit;
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_CNT_MODE_REG(cidx),
NITIO_CNT_MODE_REG(counter->
counter_index),
Gi_Counting_Mode_Mask | Gi_Index_Phase_Mask | Gi_Counting_Mode_Mask | Gi_Index_Phase_Mask |
Gi_Index_Mode_Bit, counting_mode_bits); Gi_Index_Mode_Bit, counting_mode_bits);
ni_tio_set_sync_mode(counter, 0); ni_tio_set_sync_mode(counter, 0);
} }
ni_tio_set_bits(counter, NITIO_CMD_REG(counter->counter_index), ni_tio_set_bits(counter, NITIO_CMD_REG(cidx),
Gi_Up_Down_Mask, Gi_Up_Down_Mask,
(mode >> NI_GPCT_COUNTING_DIRECTION_SHIFT) << (mode >> NI_GPCT_COUNTING_DIRECTION_SHIFT) <<
Gi_Up_Down_Shift); Gi_Up_Down_Shift);
...@@ -532,8 +521,7 @@ static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode) ...@@ -532,8 +521,7 @@ static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode)
input_select_bits |= Gi_Or_Gate_Bit; input_select_bits |= Gi_Or_Gate_Bit;
if (mode & NI_GPCT_INVERT_OUTPUT_BIT) if (mode & NI_GPCT_INVERT_OUTPUT_BIT)
input_select_bits |= Gi_Output_Polarity_Bit; input_select_bits |= Gi_Output_Polarity_Bit;
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_INPUT_SEL_REG(cidx),
NITIO_INPUT_SEL_REG(counter->counter_index),
Gi_Gate_Select_Load_Source_Bit | Gi_Or_Gate_Bit | Gi_Gate_Select_Load_Source_Bit | Gi_Or_Gate_Bit |
Gi_Output_Polarity_Bit, input_select_bits); Gi_Output_Polarity_Bit, input_select_bits);
...@@ -543,7 +531,7 @@ static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode) ...@@ -543,7 +531,7 @@ static int ni_tio_set_counter_mode(struct ni_gpct *counter, unsigned mode)
int ni_tio_arm(struct ni_gpct *counter, int arm, unsigned start_trigger) int ni_tio_arm(struct ni_gpct *counter, int arm, unsigned start_trigger)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
unsigned cidx = counter->counter_index;
unsigned command_transient_bits = 0; unsigned command_transient_bits = 0;
if (arm) { if (arm) {
...@@ -581,9 +569,7 @@ int ni_tio_arm(struct ni_gpct *counter, int arm, unsigned start_trigger) ...@@ -581,9 +569,7 @@ int ni_tio_arm(struct ni_gpct *counter, int arm, unsigned start_trigger)
} }
break; break;
} }
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_CNT_MODE_REG(cidx),
NITIO_CNT_MODE_REG
(counter->counter_index),
Gi_HW_Arm_Select_Mask Gi_HW_Arm_Select_Mask
(counter_dev->variant) | (counter_dev->variant) |
Gi_HW_Arm_Enable_Bit, Gi_HW_Arm_Enable_Bit,
...@@ -592,8 +578,7 @@ int ni_tio_arm(struct ni_gpct *counter, int arm, unsigned start_trigger) ...@@ -592,8 +578,7 @@ int ni_tio_arm(struct ni_gpct *counter, int arm, unsigned start_trigger)
} else { } else {
command_transient_bits |= Gi_Disarm_Bit; command_transient_bits |= Gi_Disarm_Bit;
} }
ni_tio_set_bits_transient(counter, ni_tio_set_bits_transient(counter, NITIO_CMD_REG(cidx),
NITIO_CMD_REG(counter->counter_index),
0, 0, command_transient_bits); 0, 0, command_transient_bits);
return 0; return 0;
} }
...@@ -717,8 +702,8 @@ static void ni_tio_set_source_subselect(struct ni_gpct *counter, ...@@ -717,8 +702,8 @@ static void ni_tio_set_source_subselect(struct ni_gpct *counter,
unsigned int clock_source) unsigned int clock_source)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned second_gate_reg = unsigned cidx = counter->counter_index;
NITIO_GATE2_REG(counter->counter_index); const unsigned second_gate_reg = NITIO_GATE2_REG(cidx);
if (counter_dev->variant != ni_gpct_variant_m_series) if (counter_dev->variant != ni_gpct_variant_m_series)
return; return;
...@@ -747,6 +732,7 @@ static int ni_tio_set_clock_src(struct ni_gpct *counter, ...@@ -747,6 +732,7 @@ static int ni_tio_set_clock_src(struct ni_gpct *counter,
unsigned int period_ns) unsigned int period_ns)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
unsigned cidx = counter->counter_index;
unsigned input_select_bits = 0; unsigned input_select_bits = 0;
static const uint64_t pico_per_nano = 1000; static const uint64_t pico_per_nano = 1000;
...@@ -766,8 +752,7 @@ static int ni_tio_set_clock_src(struct ni_gpct *counter, ...@@ -766,8 +752,7 @@ static int ni_tio_set_clock_src(struct ni_gpct *counter,
} }
if (clock_source & NI_GPCT_INVERT_CLOCK_SRC_BIT) if (clock_source & NI_GPCT_INVERT_CLOCK_SRC_BIT)
input_select_bits |= Gi_Source_Polarity_Bit; input_select_bits |= Gi_Source_Polarity_Bit;
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_INPUT_SEL_REG(cidx),
NITIO_INPUT_SEL_REG(counter->counter_index),
Gi_Source_Select_Mask | Gi_Source_Polarity_Bit, Gi_Source_Select_Mask | Gi_Source_Polarity_Bit,
input_select_bits); input_select_bits);
ni_tio_set_source_subselect(counter, clock_source); ni_tio_set_source_subselect(counter, clock_source);
...@@ -791,9 +776,7 @@ static int ni_tio_set_clock_src(struct ni_gpct *counter, ...@@ -791,9 +776,7 @@ static int ni_tio_set_clock_src(struct ni_gpct *counter,
return -EINVAL; return -EINVAL;
break; break;
} }
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_CNT_MODE_REG(cidx),
NITIO_CNT_MODE_REG(counter->
counter_index),
Gi_Prescale_X2_Bit(counter_dev->variant) | Gi_Prescale_X2_Bit(counter_dev->variant) |
Gi_Prescale_X8_Bit(counter_dev->variant), Gi_Prescale_X8_Bit(counter_dev->variant),
counting_mode_bits); counting_mode_bits);
...@@ -806,15 +789,12 @@ static int ni_tio_set_clock_src(struct ni_gpct *counter, ...@@ -806,15 +789,12 @@ static int ni_tio_set_clock_src(struct ni_gpct *counter,
static unsigned ni_tio_clock_src_modifiers(const struct ni_gpct *counter) static unsigned ni_tio_clock_src_modifiers(const struct ni_gpct *counter)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned counting_mode_bits = ni_tio_get_soft_copy(counter, unsigned cidx = counter->counter_index;
NITIO_CNT_MODE_REG const unsigned counting_mode_bits =
(counter-> ni_tio_get_soft_copy(counter, NITIO_CNT_MODE_REG(cidx));
counter_index));
unsigned bits = 0; unsigned bits = 0;
if (ni_tio_get_soft_copy(counter, if (ni_tio_get_soft_copy(counter, NITIO_INPUT_SEL_REG(cidx)) &
NITIO_INPUT_SEL_REG
(counter->counter_index)) &
Gi_Source_Polarity_Bit) Gi_Source_Polarity_Bit)
bits |= NI_GPCT_INVERT_CLOCK_SRC_BIT; bits |= NI_GPCT_INVERT_CLOCK_SRC_BIT;
if (counting_mode_bits & Gi_Prescale_X2_Bit(counter_dev->variant)) if (counting_mode_bits & Gi_Prescale_X2_Bit(counter_dev->variant))
...@@ -827,15 +807,13 @@ static unsigned ni_tio_clock_src_modifiers(const struct ni_gpct *counter) ...@@ -827,15 +807,13 @@ static unsigned ni_tio_clock_src_modifiers(const struct ni_gpct *counter)
static unsigned ni_m_series_clock_src_select(const struct ni_gpct *counter) static unsigned ni_m_series_clock_src_select(const struct ni_gpct *counter)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned second_gate_reg = unsigned cidx = counter->counter_index;
NITIO_GATE2_REG(counter->counter_index); const unsigned second_gate_reg = NITIO_GATE2_REG(cidx);
unsigned clock_source = 0; unsigned clock_source = 0;
unsigned i; unsigned i;
const unsigned input_select = (ni_tio_get_soft_copy(counter, const unsigned input_select =
NITIO_INPUT_SEL_REG (ni_tio_get_soft_copy(counter, NITIO_INPUT_SEL_REG(cidx)) &
(counter->counter_index)) Gi_Source_Select_Mask) >> Gi_Source_Select_Shift;
& Gi_Source_Select_Mask) >>
Gi_Source_Select_Shift;
switch (input_select) { switch (input_select) {
case NI_M_Series_Timebase_1_Clock: case NI_M_Series_Timebase_1_Clock:
...@@ -895,12 +873,11 @@ static unsigned ni_m_series_clock_src_select(const struct ni_gpct *counter) ...@@ -895,12 +873,11 @@ static unsigned ni_m_series_clock_src_select(const struct ni_gpct *counter)
static unsigned ni_660x_clock_src_select(const struct ni_gpct *counter) static unsigned ni_660x_clock_src_select(const struct ni_gpct *counter)
{ {
unsigned clock_source = 0; unsigned clock_source = 0;
unsigned cidx = counter->counter_index;
const unsigned input_select =
(ni_tio_get_soft_copy(counter, NITIO_INPUT_SEL_REG(cidx)) &
Gi_Source_Select_Mask) >> Gi_Source_Select_Shift;
unsigned i; unsigned i;
const unsigned input_select = (ni_tio_get_soft_copy(counter,
NITIO_INPUT_SEL_REG
(counter->counter_index))
& Gi_Source_Select_Mask) >>
Gi_Source_Select_Shift;
switch (input_select) { switch (input_select) {
case NI_660x_Timebase_1_Clock: case NI_660x_Timebase_1_Clock:
...@@ -1022,6 +999,7 @@ static void ni_tio_set_first_gate_modifiers(struct ni_gpct *counter, ...@@ -1022,6 +999,7 @@ static void ni_tio_set_first_gate_modifiers(struct ni_gpct *counter,
unsigned int gate_source) unsigned int gate_source)
{ {
const unsigned mode_mask = Gi_Gate_Polarity_Bit | Gi_Gating_Mode_Mask; const unsigned mode_mask = Gi_Gate_Polarity_Bit | Gi_Gating_Mode_Mask;
unsigned cidx = counter->counter_index;
unsigned mode_values = 0; unsigned mode_values = 0;
if (gate_source & CR_INVERT) if (gate_source & CR_INVERT)
...@@ -1030,7 +1008,7 @@ static void ni_tio_set_first_gate_modifiers(struct ni_gpct *counter, ...@@ -1030,7 +1008,7 @@ static void ni_tio_set_first_gate_modifiers(struct ni_gpct *counter,
mode_values |= Gi_Rising_Edge_Gating_Bits; mode_values |= Gi_Rising_Edge_Gating_Bits;
else else
mode_values |= Gi_Level_Gating_Bits; mode_values |= Gi_Level_Gating_Bits;
ni_tio_set_bits(counter, NITIO_MODE_REG(counter->counter_index), ni_tio_set_bits(counter, NITIO_MODE_REG(cidx),
mode_mask, mode_values); mode_mask, mode_values);
} }
...@@ -1038,6 +1016,7 @@ static int ni_660x_set_first_gate(struct ni_gpct *counter, ...@@ -1038,6 +1016,7 @@ static int ni_660x_set_first_gate(struct ni_gpct *counter,
unsigned int gate_source) unsigned int gate_source)
{ {
const unsigned selected_gate = CR_CHAN(gate_source); const unsigned selected_gate = CR_CHAN(gate_source);
unsigned cidx = counter->counter_index;
/* bits of selected_gate that may be meaningful to input select register */ /* bits of selected_gate that may be meaningful to input select register */
const unsigned selected_gate_mask = 0x1f; const unsigned selected_gate_mask = 0x1f;
unsigned ni_660x_gate_select; unsigned ni_660x_gate_select;
...@@ -1075,8 +1054,7 @@ static int ni_660x_set_first_gate(struct ni_gpct *counter, ...@@ -1075,8 +1054,7 @@ static int ni_660x_set_first_gate(struct ni_gpct *counter,
return -EINVAL; return -EINVAL;
break; break;
} }
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_INPUT_SEL_REG(cidx),
NITIO_INPUT_SEL_REG(counter->counter_index),
Gi_Gate_Select_Mask, Gi_Gate_Select_Mask,
Gi_Gate_Select_Bits(ni_660x_gate_select)); Gi_Gate_Select_Bits(ni_660x_gate_select));
return 0; return 0;
...@@ -1086,6 +1064,7 @@ static int ni_m_series_set_first_gate(struct ni_gpct *counter, ...@@ -1086,6 +1064,7 @@ static int ni_m_series_set_first_gate(struct ni_gpct *counter,
unsigned int gate_source) unsigned int gate_source)
{ {
const unsigned selected_gate = CR_CHAN(gate_source); const unsigned selected_gate = CR_CHAN(gate_source);
unsigned cidx = counter->counter_index;
/* bits of selected_gate that may be meaningful to input select register */ /* bits of selected_gate that may be meaningful to input select register */
const unsigned selected_gate_mask = 0x1f; const unsigned selected_gate_mask = 0x1f;
unsigned ni_m_series_gate_select; unsigned ni_m_series_gate_select;
...@@ -1124,8 +1103,7 @@ static int ni_m_series_set_first_gate(struct ni_gpct *counter, ...@@ -1124,8 +1103,7 @@ static int ni_m_series_set_first_gate(struct ni_gpct *counter,
return -EINVAL; return -EINVAL;
break; break;
} }
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_INPUT_SEL_REG(cidx),
NITIO_INPUT_SEL_REG(counter->counter_index),
Gi_Gate_Select_Mask, Gi_Gate_Select_Mask,
Gi_Gate_Select_Bits(ni_m_series_gate_select)); Gi_Gate_Select_Bits(ni_m_series_gate_select));
return 0; return 0;
...@@ -1135,8 +1113,8 @@ static int ni_660x_set_second_gate(struct ni_gpct *counter, ...@@ -1135,8 +1113,8 @@ static int ni_660x_set_second_gate(struct ni_gpct *counter,
unsigned int gate_source) unsigned int gate_source)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned second_gate_reg = unsigned cidx = counter->counter_index;
NITIO_GATE2_REG(counter->counter_index); const unsigned second_gate_reg = NITIO_GATE2_REG(cidx);
const unsigned selected_second_gate = CR_CHAN(gate_source); const unsigned selected_second_gate = CR_CHAN(gate_source);
/* bits of second_gate that may be meaningful to second gate register */ /* bits of second_gate that may be meaningful to second gate register */
static const unsigned selected_second_gate_mask = 0x1f; static const unsigned selected_second_gate_mask = 0x1f;
...@@ -1194,8 +1172,8 @@ static int ni_m_series_set_second_gate(struct ni_gpct *counter, ...@@ -1194,8 +1172,8 @@ static int ni_m_series_set_second_gate(struct ni_gpct *counter,
unsigned int gate_source) unsigned int gate_source)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned second_gate_reg = unsigned cidx = counter->counter_index;
NITIO_GATE2_REG(counter->counter_index); const unsigned second_gate_reg = NITIO_GATE2_REG(cidx);
const unsigned selected_second_gate = CR_CHAN(gate_source); const unsigned selected_second_gate = CR_CHAN(gate_source);
/* bits of second_gate that may be meaningful to second gate register */ /* bits of second_gate that may be meaningful to second gate register */
static const unsigned selected_second_gate_mask = 0x1f; static const unsigned selected_second_gate_mask = 0x1f;
...@@ -1222,15 +1200,13 @@ int ni_tio_set_gate_src(struct ni_gpct *counter, unsigned gate_index, ...@@ -1222,15 +1200,13 @@ int ni_tio_set_gate_src(struct ni_gpct *counter, unsigned gate_index,
unsigned int gate_source) unsigned int gate_source)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned second_gate_reg = unsigned cidx = counter->counter_index;
NITIO_GATE2_REG(counter->counter_index); const unsigned second_gate_reg = NITIO_GATE2_REG(cidx);
switch (gate_index) { switch (gate_index) {
case 0: case 0:
if (CR_CHAN(gate_source) == NI_GPCT_DISABLED_GATE_SELECT) { if (CR_CHAN(gate_source) == NI_GPCT_DISABLED_GATE_SELECT) {
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_MODE_REG(cidx),
NITIO_MODE_REG(counter->
counter_index),
Gi_Gating_Mode_Mask, Gi_Gating_Mode_Mask,
Gi_Gating_Disabled_Bits); Gi_Gating_Disabled_Bits);
return 0; return 0;
...@@ -1292,11 +1268,12 @@ static int ni_tio_set_other_src(struct ni_gpct *counter, unsigned index, ...@@ -1292,11 +1268,12 @@ static int ni_tio_set_other_src(struct ni_gpct *counter, unsigned index,
unsigned int source) unsigned int source)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
unsigned cidx = counter->counter_index;
if (counter_dev->variant == ni_gpct_variant_m_series) { if (counter_dev->variant == ni_gpct_variant_m_series) {
unsigned int abz_reg, shift, mask; unsigned int abz_reg, shift, mask;
abz_reg = NITIO_ABZ_REG(counter->counter_index); abz_reg = NITIO_ABZ_REG(cidx);
switch (index) { switch (index) {
case NI_GPCT_SOURCE_ENCODER_A: case NI_GPCT_SOURCE_ENCODER_A:
shift = 10; shift = 10;
...@@ -1490,12 +1467,10 @@ static int ni_tio_get_gate_src(struct ni_gpct *counter, unsigned gate_index, ...@@ -1490,12 +1467,10 @@ static int ni_tio_get_gate_src(struct ni_gpct *counter, unsigned gate_index,
unsigned int *gate_source) unsigned int *gate_source)
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned mode_bits = ni_tio_get_soft_copy(counter, unsigned cidx = counter->counter_index;
NITIO_MODE_REG const unsigned mode_bits =
(counter-> ni_tio_get_soft_copy(counter, NITIO_MODE_REG(cidx));
counter_index)); const unsigned second_gate_reg = NITIO_GATE2_REG(cidx);
const unsigned second_gate_reg =
NITIO_GATE2_REG(counter->counter_index);
unsigned gate_select_bits; unsigned gate_select_bits;
switch (gate_index) { switch (gate_index) {
...@@ -1507,8 +1482,7 @@ static int ni_tio_get_gate_src(struct ni_gpct *counter, unsigned gate_index, ...@@ -1507,8 +1482,7 @@ static int ni_tio_get_gate_src(struct ni_gpct *counter, unsigned gate_index,
} else { } else {
gate_select_bits = gate_select_bits =
(ni_tio_get_soft_copy(counter, (ni_tio_get_soft_copy(counter,
NITIO_INPUT_SEL_REG NITIO_INPUT_SEL_REG(cidx)) &
(counter->counter_index)) &
Gi_Gate_Select_Mask) >> Gi_Gate_Select_Shift; Gi_Gate_Select_Mask) >> Gi_Gate_Select_Shift;
} }
switch (counter_dev->variant) { switch (counter_dev->variant) {
...@@ -1627,6 +1601,7 @@ int ni_tio_rinsn(struct ni_gpct *counter, struct comedi_insn *insn, ...@@ -1627,6 +1601,7 @@ int ni_tio_rinsn(struct ni_gpct *counter, struct comedi_insn *insn,
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned channel = CR_CHAN(insn->chanspec); const unsigned channel = CR_CHAN(insn->chanspec);
unsigned cidx = counter->counter_index;
unsigned first_read; unsigned first_read;
unsigned second_read; unsigned second_read;
unsigned correct_read; unsigned correct_read;
...@@ -1635,41 +1610,30 @@ int ni_tio_rinsn(struct ni_gpct *counter, struct comedi_insn *insn, ...@@ -1635,41 +1610,30 @@ int ni_tio_rinsn(struct ni_gpct *counter, struct comedi_insn *insn,
return 0; return 0;
switch (channel) { switch (channel) {
case 0: case 0:
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_CMD_REG(cidx),
NITIO_CMD_REG(counter->counter_index),
Gi_Save_Trace_Bit, 0); Gi_Save_Trace_Bit, 0);
ni_tio_set_bits(counter, ni_tio_set_bits(counter, NITIO_CMD_REG(cidx),
NITIO_CMD_REG(counter->counter_index),
Gi_Save_Trace_Bit, Gi_Save_Trace_Bit); Gi_Save_Trace_Bit, Gi_Save_Trace_Bit);
/* The count doesn't get latched until the next clock edge, so it is possible the count /* The count doesn't get latched until the next clock edge, so it is possible the count
may change (once) while we are reading. Since the read of the SW_Save_Reg isn't may change (once) while we are reading. Since the read of the SW_Save_Reg isn't
atomic (apparently even when it's a 32 bit register according to 660x docs), atomic (apparently even when it's a 32 bit register according to 660x docs),
we need to read twice and make sure the reading hasn't changed. If it has, we need to read twice and make sure the reading hasn't changed. If it has,
a third read will be correct since the count value will definitely have latched by then. */ a third read will be correct since the count value will definitely have latched by then. */
first_read = first_read = read_register(counter, NITIO_SW_SAVE_REG(cidx));
read_register(counter, second_read = read_register(counter, NITIO_SW_SAVE_REG(cidx));
NITIO_SW_SAVE_REG(counter->counter_index));
second_read =
read_register(counter,
NITIO_SW_SAVE_REG(counter->counter_index));
if (first_read != second_read) if (first_read != second_read)
correct_read = correct_read =
read_register(counter, read_register(counter, NITIO_SW_SAVE_REG(cidx));
NITIO_SW_SAVE_REG(counter->counter_index));
else else
correct_read = first_read; correct_read = first_read;
data[0] = correct_read; data[0] = correct_read;
return 0; return 0;
break; break;
case 1: case 1:
data[0] = data[0] = counter_dev->regs[NITIO_LOADA_REG(cidx)];
counter_dev->
regs[NITIO_LOADA_REG(counter->counter_index)];
break; break;
case 2: case 2:
data[0] = data[0] = counter_dev->regs[NITIO_LOADB_REG(cidx)];
counter_dev->
regs[NITIO_LOADB_REG(counter->counter_index)];
break; break;
} }
return 0; return 0;
...@@ -1678,14 +1642,14 @@ EXPORT_SYMBOL_GPL(ni_tio_rinsn); ...@@ -1678,14 +1642,14 @@ EXPORT_SYMBOL_GPL(ni_tio_rinsn);
static unsigned ni_tio_next_load_register(struct ni_gpct *counter) static unsigned ni_tio_next_load_register(struct ni_gpct *counter)
{ {
const unsigned bits = read_register(counter, unsigned cidx = counter->counter_index;
NITIO_SHARED_STATUS_REG(counter-> const unsigned bits =
counter_index)); read_register(counter, NITIO_SHARED_STATUS_REG(cidx));
if (bits & Gi_Next_Load_Source_Bit(counter->counter_index)) if (bits & Gi_Next_Load_Source_Bit(cidx))
return NITIO_LOADB_REG(counter->counter_index); return NITIO_LOADB_REG(cidx);
else else
return NITIO_LOADA_REG(counter->counter_index); return NITIO_LOADA_REG(cidx);
} }
int ni_tio_winsn(struct ni_gpct *counter, struct comedi_insn *insn, int ni_tio_winsn(struct ni_gpct *counter, struct comedi_insn *insn,
...@@ -1693,6 +1657,7 @@ int ni_tio_winsn(struct ni_gpct *counter, struct comedi_insn *insn, ...@@ -1693,6 +1657,7 @@ int ni_tio_winsn(struct ni_gpct *counter, struct comedi_insn *insn,
{ {
struct ni_gpct_device *counter_dev = counter->counter_dev; struct ni_gpct_device *counter_dev = counter->counter_dev;
const unsigned channel = CR_CHAN(insn->chanspec); const unsigned channel = CR_CHAN(insn->chanspec);
unsigned cidx = counter->counter_index;
unsigned load_reg; unsigned load_reg;
if (insn->n < 1) if (insn->n < 1)
...@@ -1703,23 +1668,18 @@ int ni_tio_winsn(struct ni_gpct *counter, struct comedi_insn *insn, ...@@ -1703,23 +1668,18 @@ int ni_tio_winsn(struct ni_gpct *counter, struct comedi_insn *insn,
/* Don't disturb load source select, just use whichever load register is already selected. */ /* Don't disturb load source select, just use whichever load register is already selected. */
load_reg = ni_tio_next_load_register(counter); load_reg = ni_tio_next_load_register(counter);
write_register(counter, data[0], load_reg); write_register(counter, data[0], load_reg);
ni_tio_set_bits_transient(counter, ni_tio_set_bits_transient(counter, NITIO_CMD_REG(cidx),
NITIO_CMD_REG(counter->counter_index),
0, 0, Gi_Load_Bit); 0, 0, Gi_Load_Bit);
/* restore state of load reg to whatever the user set last set it to */ /* restore state of load reg to whatever the user set last set it to */
write_register(counter, counter_dev->regs[load_reg], load_reg); write_register(counter, counter_dev->regs[load_reg], load_reg);
break; break;
case 1: case 1:
counter_dev->regs[NITIO_LOADA_REG(counter->counter_index)] = counter_dev->regs[NITIO_LOADA_REG(cidx)] = data[0];
data[0]; write_register(counter, data[0], NITIO_LOADA_REG(cidx));
write_register(counter, data[0],
NITIO_LOADA_REG(counter->counter_index));
break; break;
case 2: case 2:
counter_dev->regs[NITIO_LOADB_REG(counter->counter_index)] = counter_dev->regs[NITIO_LOADB_REG(cidx)] = data[0];
data[0]; write_register(counter, data[0], NITIO_LOADB_REG(cidx));
write_register(counter, data[0],
NITIO_LOADB_REG(counter->counter_index));
break; break;
default: default:
return -EINVAL; return -EINVAL;
......
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