| #!/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 |
| |
| # FIXME: getting two bits |
| # 00_40 31_46 |
| # Can we find instance where they are not aliased? |
| WA7USED = 0 |
| |
| from prjxray.segmaker import Segmaker |
| |
| segmk = Segmaker("design.bits") |
| |
| print("Loading tags") |
| ''' |
| module,loc,c31,b31,a31 |
| my_NDI1MUX_NI_NMC31,SLICE_X12Y100,1,1,0 |
| my_NDI1MUX_NI_NMC31,SLICE_X12Y101,1,1,1 |
| my_NDI1MUX_NI_NMC31,SLICE_X12Y102,1,1,1 |
| ''' |
| f = open('params.csv', 'r') |
| f.readline() |
| for l in f: |
| l = l.strip() |
| module, loc, c31, b31, a31 = l.split(',') |
| c31 = int(c31) |
| b31 = int(b31) |
| a31 = int(a31) |
| segmk.add_site_tag(loc, "ALUT.DI1MUX.AI", 1 ^ a31) |
| segmk.add_site_tag(loc, "ALUT.DI1MUX.BDI1_BMC31", a31) |
| segmk.add_site_tag(loc, "BLUT.DI1MUX.BI", 1 ^ b31) |
| segmk.add_site_tag(loc, "BLUT.DI1MUX.DI_CMC31", b31) |
| segmk.add_site_tag(loc, "CLUT.DI1MUX.CI", 1 ^ c31) |
| segmk.add_site_tag(loc, "CLUT.DI1MUX.DI_DMC31", c31) |
| |
| segmk.compile() |
| segmk.write() |