This file is indexed.

/usr/share/tkgate/primitives/README is in tkgate-data 2.0~b10-4ubuntu2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
This directory contains verilog templates for all of the built-in
gates.  User editing of these templates is not currently supported
because, but can be done subject to the following caveats:
 * the syntax is still subject to change across releases.
 * changing the order of module parameters in a template is not
   guaranteed to work.

SUBSTITUTION:

Variable substitutions are indicated with a sequence of the form
"${NAME}".  If "NAME" is a template parameter for a gate type, the
value of that variable will be substituted.

GENERATION:

Generating sequences have the form "$${NAME:str}" or
"$${NAME:sep:str}".  The variable "NAME" is assumed to be a numeric
value for the number of times to generate the string "str".  If there
is a "%" character in the string, it will be replaced with the decimal
value of the count starting at "0".  The second form is similar to the
first except that the string "sep" will be placed between each
instance of "sep" that is generated.  The "sep" and "str" strings
themselves may also contain variable substitution sequences.

PARAMETER NAMING CONVENTIONS:

By convention, parameter names that end in "_RANGE" are bit or memory
range strings having the form "[msb:0]" or "[0:max]".  Parameters that
end in "_BITS" expand to numbers representing the number of bits
in the corresponding "_RANGE" parameter.  The parameters names "NUMIN"
and "NUMOUT" are used for gates with a variable number of inputs or
outputs, respectively.  Finally, names of the form "invX" contain
either a "~" or an empty string depending on whether the output "X"
requires an inverter.

LIST OF TEMPLATE PARAMETERS:

and, or, xor:
	NUMIN		Number of inputs
	Z_RANGE		Bit range of output
	I_RANGE		Bit range of input
	invZ		Optional inverter on Z output

rand, ror, rxor:
	Z_RANGE		Bit range of output
	I_RANGE		Bit range of input
	invZ		Optional inverter on Z output

flipflop:
	DQ_RANGE	Bit range of D/Q input/output.
	DQ_BITS		Number of bits on D/Q input/output.
	invQ		Optional inverter on Q output.
	invNQ		Optional inverter on _Q output.

register:
	DQ_RANGE	Bit range of D/Q input/output.
	DQ_BITS		Number of bits on D/Q input/output.
	invQ		Optional inverter on Q output.

adder:
	ABS_RANGE	Bit range of A, B and S inputs/output
	invCO		Optional inverter on CO output.
	invS		Optional inverter on S output.

mult:
	AB_RANGE	Bit range of A and B inputs
	P_RANGE		Bit range of P output
	invP		Optional inverter on P output.

div:
	ABQR_RANGE	Bit range of A, B, Q and R inputs/output
	invQ		Optional inverter on Q output.
	invR		Optional inverter on R output.

lshift, rshift, arshift:
	IZ_RANGE	Bit range of I/Z input/output
	S_RANGE		Bit range of S input
	invZ		Optional inverter on Z output.

roll:
	IZ_RANGE	Bit range of I/Z input/output
	IZ_BITS		Number of bits of I/Z input/output
	S_RANGE		Bit range of S input
	invZ		Optional inverter on Z output.

clock:
	PHASE		Time to wait before entering loop
	INITIAL		Initial value of clock
	ON_TIME		Time clock is "on"
	OFF_TIME	Time clock is "off"
	invZ		Optional inverter on Z output.

mux:
	NUMIN		Number of data inputs
	IZ_RANGE	Bit range of inputs/output
	S_RANGE		Bit range of S input

demux:
	NUMOUT		Number of outputs
	OUT_RANGE	Bit range of internal output net.
	I_RANGE		Bit range of input I.
	invZ		Bit-by-bit inversion for outputs

ram:
	A_RANGE		Bit range of address line
	D_RANGE		Bit range of data line
	D_BITS		Number of bits in data line
	MEM_RANGE	Memory address range.

rom:
	A_RANGE		Bit range of address line
	D_RANGE		Bit range of data line
	D_BITS		Number of bits in data line.
	MEM_RANGE	Memory address range.
	invD		Optional inverter on D output.

nmos_trans, pmos_trans:
	SGZ_RANGE	Bit range of source, gate and drain.
	invZ		Optional inverter on Z output.

buf:
	IZ_RANGE	Bit range of input/output
	invZ		Optional inverter on Z output.

tribuf:
	IZ_RANGE	Bit range of inputs/output
	IZ_BITS		Number of bits in inputs/output
	invZ		Optional inverter on Z output.