blob: 37809eb67f52dda65d320293f4ca7c1d7e03ba62 [file] [log] [blame]
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# Copyright (C) 2017-2020 The Project X-Ray Authors.
#
# Use of this source code is governed by a ISC-style
# license that can be found in the LICENSE file or at
# https://opensource.org/licenses/ISC
#
# SPDX-License-Identifier: ISC
import os
import json
import random
random.seed(int(os.getenv("SEED"), 16))
from prjxray import util
def gen_sites():
for tile_name, site_name, _site_type in sorted(util.get_roi().gen_sites(
['RAMB18E1', 'FIFO18E1'])):
yield tile_name, site_name
BITS_PER_PARAM = 256
NUM_INITP_PARAMS = 8
NUM_INIT_PARAMS = 0x40
BITS_PER_SITE = BITS_PER_PARAM * (NUM_INITP_PARAMS + NUM_INIT_PARAMS)
def main():
print("module top();")
list_of_params = []
for tile_name, site in gen_sites():
params = {}
params['tile'] = tile_name
params['site'] = site
p = []
for initp_idx in range(NUM_INITP_PARAMS):
param = 'INITP_{:02X}'.format(initp_idx)
params[param] = random.randint(0, 2**BITS_PER_PARAM - 1)
p.append(
".{param}(256'h{val:x})".format(
param=param, val=params[param]))
for init_idx in range(NUM_INIT_PARAMS):
param = 'INIT_{:02X}'.format(init_idx)
params[param] = random.randint(0, 2**BITS_PER_PARAM - 1)
p.append(
".{param}(256'h{val:x})".format(
param=param, val=params[param]))
params['params'] = ','.join(p)
print(
"""
(* KEEP, DONT_TOUCH, LOC = "{site}" *)
RAMB18E1 #(
.READ_WIDTH_A(1),
.READ_WIDTH_B(1),
.RAM_MODE("TDP"),
{params}
) bram_{site} (
);
""".format(**params))
list_of_params.append(params)
print("endmodule")
with open('params.json', 'w') as f:
json.dump(list_of_params, f, indent=2)
if __name__ == "__main__":
main()