aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/top/x400/regmap/versioning_utils.vh
blob: 9ef1889979325ba96945d0fd36f6fd16b7bc86b7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
//
// Copyright 2021 Ettus Research, a National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
// Module: versioning_utils
//
// Description:
//
//  Contains constants and functions for versioning purposes
//
//  IMPORTANT! The constants and functions defined in this file depend
//             on versioning_regs_regmap_utils.vh, which must be
//             included before this file.
//


// Each component consists of 3 x 32-bit values (96-bit total)
// The component's versions are located in the flat component's
// version vector as shown below, following the same order in which
// the registers' offsets are implemented.
//
// Version element             Bit ranges  32-bit word position
//  Current version             [31: 0]     0
//  Oldest compatible version   [63:32]     1
//  Last modified               [95:64]     2

localparam COMPONENT_VERSIONS_SIZE =
  TIMESTAMP_TYPE_SIZE + VERSION_TYPE_SIZE + VERSION_TYPE_SIZE; // 96

// There are up to 64 addressable components' versions in the
// versioning module's version_info input vector.
localparam MAX_NUM_OF_COMPONENTS = 64;

// Define constants for each field's LSB in the flat vector.
//   Start bit = 8-bit * (register offset with index 0)
localparam CURRENT_VERSION_LSB           = 8 * CURRENT_VERSION(0);           // 0
localparam OLDEST_COMPATIBLE_VERSION_LSB = 8 * OLDEST_COMPATIBLE_VERSION(0); // 32
localparam TIMESTAMP_LSB                 = 8 * VERSION_LAST_MODIFIED(0);     // 64

// This function takes the major, minor and build values for the current
// version field, and returns a vector of size VERSION_TYPE_SIZE
// that contains those fields at the proper location.
function automatic [VERSION_TYPE_SIZE-1:0] build_version;
  input [MAJOR_SIZE-1:0] major;
  input [MINOR_SIZE-1:0] minor;
  input [BUILD_SIZE-1:0] build;
begin
  build_version[MAJOR+:MAJOR_SIZE] = major;
  build_version[MINOR+:MINOR_SIZE] = minor;
  build_version[BUILD+:BUILD_SIZE] = build;
end
endfunction

// This function takes the 3 versioning fields that comprise a component's
// version (current, oldest compatible, timestamp), and concatenates them
// in the expected order (see details above).
// The function returns a vector of size COMPONENT_VERSIONS_SIZE with
// all the component's versions.
function automatic [COMPONENT_VERSIONS_SIZE-1:0] build_component_versions;
  input [TIMESTAMP_TYPE_SIZE-1:0]                timestamp;
  input [VERSION_TYPE_SIZE-1:0]  oldest_compatible_version;
  input [VERSION_TYPE_SIZE-1:0]            current_version;
begin
    // Current version mapping
    build_component_versions[CURRENT_VERSION_LSB +: VERSION_TYPE_SIZE] = current_version;
    // Oldest compatible version mapping
    build_component_versions[OLDEST_COMPATIBLE_VERSION_LSB +: VERSION_TYPE_SIZE] = oldest_compatible_version;
    // Last modified
    build_component_versions[TIMESTAMP_LSB +: TIMESTAMP_TYPE_SIZE] = timestamp;
end
endfunction

// This function retrieves a component's version information, based on the
// provided index, from the vector containing all the components' versions.
function automatic [COMPONENT_VERSIONS_SIZE-1:0] get_component_versions;
  input [MAX_NUM_OF_COMPONENTS*COMPONENT_VERSIONS_SIZE-1:0] version_info_vector;
  input integer                                             component_index;
begin
  get_component_versions = version_info_vector[COMPONENT_VERSIONS_SIZE*component_index +: COMPONENT_VERSIONS_SIZE];
end
endfunction

// This function takes a component's version info and returns the
// current version field.
function automatic [VERSION_TYPE_SIZE-1:0] current_version;
  input [COMPONENT_VERSIONS_SIZE-1:0] component_versions;
begin
  current_version = component_versions[CURRENT_VERSION_LSB +: VERSION_TYPE_SIZE];
end
endfunction

// This function takes a component's version info and returns the
// oldest compatible version field.
function automatic [VERSION_TYPE_SIZE-1:0] oldest_compatible_version;
  input [COMPONENT_VERSIONS_SIZE-1:0] component_versions;
begin
  oldest_compatible_version = component_versions[OLDEST_COMPATIBLE_VERSION_LSB +: VERSION_TYPE_SIZE];
end
endfunction

// This function takes a component's version info and returns the
// version last modified field.
function automatic [VERSION_TYPE_SIZE-1:0] version_last_modified;
  input [COMPONENT_VERSIONS_SIZE-1:0] component_versions;
begin
  version_last_modified = component_versions[TIMESTAMP_LSB +: TIMESTAMP_TYPE_SIZE];
end
endfunction