description = "Unit generating PPS signals and acting as a UTC real-time clock";
description = "Unit generating PPS signals and acting as a UTC real-time clock";
hdl_entity = "pps_gen_wb";
hdl_entity = "pps_gen_wb";
prefix = "ppsg";
prefix = "ppsg";
reg {
reg {
name = "Control Register";
name = "Control Register";
prefix = "CR";
prefix = "CR";
field {
field {
name = "Reset counter";
name = "Reset counter";
description = "write 1: resets the counter\
description = "write 1: resets the counter\
write 0: no effect";
write 0: no effect";
prefix = "CNT_RST";
prefix = "CNT_RST";
type = MONOSTABLE;
type = MONOSTABLE;
clock = "refclk_i";
clock = "refclk_i";
};
};
field {
field {
name = "Enable counter";
name = "Enable counter";
description = "1: PPS counter is enabled";
description = "1: PPS counter is enabled";
prefix = "CNT_EN";
prefix = "CNT_EN";
type = BIT;
type = BIT;
access_bus = READ_WRITE;
access_bus = READ_WRITE;
access_dev = READ_ONLY;
access_dev = READ_ONLY;
clock = "refclk_i";
clock = "refclk_i";
};
};
field {
field {
name = "Adjust offset";
name = "Adjust offset";
description = "write 1: Starts adjusting PPS/UTC offsets by adding the values taken from ADJ_NSEC, ADJ_UTCLO, ADJ_UTCHI registers to the current PPS counter value. These registers need to be programmed prior to update.\
description = "write 1: Starts adjusting PPS/UTC offsets by adding the values taken from ADJ_NSEC, ADJ_UTCLO, ADJ_UTCHI registers to the current PPS counter value. These registers need to be programmed prior to update.\
write 0: no effect\
write 0: no effect\
read 0: adjustment operation is done\
read 0: adjustment operation is done\
read 1: adjustment operation is in progress";
read 1: adjustment operation is in progress";
prefix = "CNT_ADJ";
prefix = "CNT_ADJ";
type = BIT;
type = BIT;
access_bus = READ_WRITE;
access_bus = READ_WRITE;
access_dev = READ_WRITE;
access_dev = READ_WRITE;
load = LOAD_EXT;
load = LOAD_EXT;
clock = "refclk_i";
clock = "refclk_i";
};
};
field {
field {
name = "Set time";
name = "Set time";
description = "write 1: Sets the UTC/PPS counter to values taken from ADJ_NSEC, ADJ_UTCLO, ADJ_UTCHI registers";
description = "write 1: Sets the UTC/PPS counter to values taken from ADJ_NSEC, ADJ_UTCLO, ADJ_UTCHI registers";
prefix = "CNT_SET";
prefix = "CNT_SET";
type = MONOSTABLE;
type = MONOSTABLE;
clock = "refclk_i";
clock = "refclk_i";
};
};
field {
field {
name = "PPS Pulse width";
name = "PPS Pulse width";
description = "Width of generated PPS pulses in 125 MHz refernce clock cycles";
description = "Width of generated PPS pulses in 125 MHz refernce clock cycles";
prefix = "PWIDTH";
prefix = "PWIDTH";
size = 28;
size = 28;
type = SLV;
type = SLV;
access_bus = READ_WRITE;
access_bus = READ_WRITE;
access_dev = READ_ONLY;
access_dev = READ_ONLY;
clock= "refclk_i";
clock= "refclk_i";
};
};
};
};
reg {
reg {
name = "Nanosecond counter register";
name = "Nanosecond counter register";
description = "Nanosecond part of current time, expressed as number of 125 MHz reference clock cycles";
description = "Nanosecond part of current time, expressed as number of 125 MHz reference clock cycles";
prefix = "CNTR_NSEC";
prefix = "CNTR_NSEC";
field {
field {
name = "Nanosecond counter";
name = "Nanosecond counter";
type = SLV;
type = SLV;
size = 28;
size = 28;
access_bus = READ_ONLY;
access_bus = READ_ONLY;
access_dev = WRITE_ONLY;
access_dev = WRITE_ONLY;
clock = "refclk_i";
clock = "refclk_i";
};
};
};
};
reg {
reg {
name = "UTC Counter register (least-significant part)";
name = "UTC Counter register (least-significant part)";
description = "Lower 32 bits of current UTC time";
description = "Lower 32 bits of current UTC time";
prefix = "CNTR_UTCLO";
prefix = "CNTR_UTCLO";
field {
field {
name = "UTC Counter";
name = "UTC Counter";
type = SLV;
type = SLV;
size = 32;
size = 32;
access_bus = READ_ONLY;
access_bus = READ_ONLY;
access_dev = WRITE_ONLY;
access_dev = WRITE_ONLY;
clock = "refclk_i";
clock = "refclk_i";
};
};
};
};
reg {
reg {
name = "UTC Counter register (most-significant part)";
name = "UTC Counter register (most-significant part)";
description = "Highest 8 bits of current UTC time";
description = "Highest 8 bits of current UTC time";
prefix = "CNTR_UTCHI";
prefix = "CNTR_UTCHI";
field {
field {
name = "UTC Counter";
name = "UTC Counter";
type = SLV;
type = SLV;
size = 8;
size = 8;
access_bus = READ_ONLY;
access_bus = READ_ONLY;
access_dev = WRITE_ONLY;
access_dev = WRITE_ONLY;
clock = "refclk_i";
clock = "refclk_i";
};
};
};
};
reg {
reg {
name = "Nanosecond adjustment register";
name = "Nanosecond adjustment register";
description = "Adjustment value for nanosecond counter";
description = "Adjustment value for nanosecond counter";
prefix = "ADJ_NSEC";
prefix = "ADJ_NSEC";
field {
field {
name = "Nanosecond adjustment";
name = "Nanosecond adjustment";
type = PASS_THROUGH;
type = PASS_THROUGH;
size = 28;
size = 28;
};
};
};
};
reg {
reg {
name = "UTC Adjustment register (least-significant part)";
name = "UTC Adjustment register (least-significant part)";
description = "Lower 32 bits of adjustment value for UTC";
description = "Lower 32 bits of adjustment value for UTC";
prefix = "ADJ_UTCLO";
prefix = "ADJ_UTCLO";
field {
field {
name = "UTC Counter adjustment";
name = "UTC Counter adjustment";
type = PASS_THROUGH;
type = PASS_THROUGH;
size = 32;
size = 32;
};
};
};
};
reg {
reg {
name = "UTC Adjustment register (most-significant part)";
name = "UTC Adjustment register (most-significant part)";
description = "Highest 8 bits of adjustment value for UTC";
description = "Highest 8 bits of adjustment value for UTC";
prefix = "ADJ_UTCHI";
prefix = "ADJ_UTCHI";
field {
field {
name = "UTC Counter adjustment";
name = "UTC Counter adjustment";
type = PASS_THROUGH;
type = PASS_THROUGH;
size = 8;
size = 8;
};
};
};
};
reg {
reg {
name = "External sync control register";
name = "External sync control register";
prefix = "ESCR";
prefix = "ESCR";
field {
field {
name = "Sync to external PPS input";
name = "Sync to external PPS input";
description = "write 1: Waits until a pulse on external PPS input arrives and re-synchronizes the PPS counter to it\
description = "write 1: Waits until a pulse on external PPS input arrives and re-synchronizes the PPS counter to it\
write 0: no effect\
write 0: no effect\
read 1: external synchronization done\
read 1: external synchronization done\
read 0: external synchronization in progress";
read 0: external synchronization in progress";
type = BIT;
type = BIT;
prefix = "SYNC";
prefix = "SYNC";
access_bus = READ_WRITE;
access_bus = READ_WRITE;
access_dev = READ_WRITE;
access_dev = READ_WRITE;
load = LOAD_EXT;
load = LOAD_EXT;
clock = "refclk_i";
clock = "refclk_i";
};
};
field {
name = "PPS unmask output";
description = "write 1: Always enable PPS output when PPS valid is set (useful for free-running master mode)\
write 0: Automatically mask PPS output when link is down (default)";
prefix = "PPS_UNMASK";
type = BIT;
access_bus = READ_WRITE;
access_dev = READ_ONLY;
clock = "refclk_i";
};
field {
field {
name = "PPS output valid";
name = "PPS output valid";
...
@@ -192,23 +203,23 @@ peripheral {
...
@@ -192,23 +203,23 @@ peripheral {
clock = "refclk_i";
clock = "refclk_i";
};
};
field {
field {
name = "Set seconds counter";
name = "Set seconds counter";
description = "write 1: set seconds counter to the value stored in ADJ_UTCLO and ADJ_UTCHI. Nanoseconds counter stays unchanged.\
description = "write 1: set seconds counter to the value stored in ADJ_UTCLO and ADJ_UTCHI. Nanoseconds counter stays unchanged.\
write 0: no effect";
write 0: no effect";
prefix = "SEC_SET";
prefix = "SEC_SET";
type = MONOSTABLE;
type = MONOSTABLE;
clock = "refclk_i";
clock = "refclk_i";
};
};
field {
field {
name = "Set nanoseconds counter";
name = "Set nanoseconds counter";
description = "write 1: set nanoseconds counter to the value stored in ADJ_NSEC. Seconds counter stays unchanged.\
description = "write 1: set nanoseconds counter to the value stored in ADJ_NSEC. Seconds counter stays unchanged.\