|  | #!/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 | 
|  |  | 
|  | from prjxray.segmaker import Segmaker | 
|  | from prjxray import segmaker | 
|  | from prjxray import verilog | 
|  | import os | 
|  | import json | 
|  | import csv | 
|  |  | 
|  |  | 
|  | def bitfilter(frame, word): | 
|  | if frame not in [26, 27]: | 
|  | return False | 
|  | return True | 
|  |  | 
|  | def main(): | 
|  | print("Loading tags") | 
|  | segmk = Segmaker("design.bits") | 
|  |  | 
|  | with open('params.json', 'r') as f: | 
|  | design = json.load(f) | 
|  |  | 
|  | for d in design['tiles']: | 
|  | print("design: " + str(d)) | 
|  | site = d['site'] | 
|  | tile = d['tile'] | 
|  |  | 
|  | connection = d['CONNECTION'] | 
|  |  | 
|  | if site.startswith('STARTUP'): | 
|  | segmk.add_site_tag(site, 'USRCCLKO_CONNECTED', connection == "CLOCK") | 
|  |  | 
|  | segmk.compile(bitfilter=bitfilter) | 
|  | segmk.write(allow_empty=True) | 
|  |  | 
|  | if __name__ == "__main__": | 
|  | main() |