f4pga/wrappers/sh/quicklogic: rm fasm2bels.f4pga.sh
Signed-off-by: Unai Martinez-Corral <umartinezcorral@antmicro.com>
This commit is contained in:
parent
dab5de2d1f
commit
5d0642249d
|
@ -239,7 +239,50 @@ def ql():
|
||||||
|
|
||||||
def fasm2bels():
|
def fasm2bels():
|
||||||
print("[F4PGA] Running (deprecated) fasm2bels")
|
print("[F4PGA] Running (deprecated) fasm2bels")
|
||||||
run_sh_script(ROOT / "quicklogic/fasm2bels.f4pga.sh")
|
run_bash_cmds(f"""
|
||||||
|
set -e
|
||||||
|
SHARE_DIR_PATH=${{SHARE_DIR_PATH:="$F4PGA_SHARE_DIR"}}
|
||||||
|
eval set -- "$(
|
||||||
|
getopt \
|
||||||
|
--options=d:P:p:b:v:o:q \
|
||||||
|
--longoptions=device:,part:,pcf:,bit:,out-verilog:,out-pcf:,out-qcf:, \
|
||||||
|
--name $0 -- {' '.join(sys_argv[1:])}
|
||||||
|
)"
|
||||||
|
DEVICE=""
|
||||||
|
PART=""
|
||||||
|
PCF=""
|
||||||
|
BIT=""
|
||||||
|
OUT_VERILOG=""
|
||||||
|
OUT_PCF=""
|
||||||
|
OUT_QCF=""
|
||||||
|
while true; do
|
||||||
|
case "$1" in
|
||||||
|
-d|--device) DEVICE=$2; shift 2 ;;
|
||||||
|
-P|--part) PART=$2; shift 2 ;;
|
||||||
|
-p|--pcf) PCF=$2; shift 2 ;;
|
||||||
|
-b|--bit) BIT=$2; shift 2 ;;
|
||||||
|
-v|--out-verilog) OUT_VERILOG=$2; shift 2 ;;
|
||||||
|
-o|--out-pcf) OUT_PCF=$2; shift 2 ;;
|
||||||
|
-q|--out-qcf) OUT_QCF=$2; shift 2 ;;
|
||||||
|
--) break ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
if [ -z $DEVICE ]; then echo "Please provide device name"; exit 1; fi
|
||||||
|
if [ -z $BIT ]; then echo "Please provide an input bistream file name"; exit 1; fi
|
||||||
|
# $DEVICE is not ql-eos-s3 or ql-pp3e
|
||||||
|
if ! [[ "$DEVICE" =~ ^(ql-eos-s3|ql-pp3e)$ ]]; then echo "ERROR: Unsupported device '${{DEVICE}}' for fasm2bels"; exit -1; fi
|
||||||
|
if [ -z "{{PCF}}" ]; then PCF_ARGS=""; else PCF_ARGS="--input-pcf ${{PCF}}"; fi
|
||||||
|
echo "Running fasm2bels"
|
||||||
|
`which python3` "`readlink -f ${{SHARE_DIR_PATH}}/scripts/fasm2bels.py`" "${{BIT}}" \
|
||||||
|
--phy-db "`readlink -f ${{SHARE_DIR_PATH}}/arch/${{DEVICE}}_wlcsp/db_phy.pickle`" \
|
||||||
|
--device-name "${{DEVICE/ql-/}}" \
|
||||||
|
--package-name "$PART" \
|
||||||
|
--input-type bitstream \
|
||||||
|
--output-verilog "${{OUT_VERILOG:-$BIT.v}}" \
|
||||||
|
${{PCF_ARGS}} \
|
||||||
|
--output-pcf "${{OUT_PCF:-$BIT.v.pcf}}" \
|
||||||
|
--output-qcf "${{OUT_QCF:-$BIT.v.qcf}}"
|
||||||
|
""")
|
||||||
|
|
||||||
|
|
||||||
def write_bitheader():
|
def write_bitheader():
|
||||||
|
|
|
@ -1,88 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
# Copyright (C) 2020-2022 F4PGA Authors.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# https://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
#
|
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
SHARE_DIR_PATH=${SHARE_DIR_PATH:="$F4PGA_SHARE_DIR"}
|
|
||||||
|
|
||||||
OPTS=d:P:p:b:v:o:q
|
|
||||||
LONGOPTS=device:,part:,pcf:,bit:,out-verilog:,out-pcf:,out-qcf:,
|
|
||||||
|
|
||||||
PARSED_OPTS=`getopt --options=${OPTS} --longoptions=${LONGOPTS} --name $0 -- "$@"`
|
|
||||||
eval set -- "${PARSED_OPTS}"
|
|
||||||
|
|
||||||
DEVICE=""
|
|
||||||
PART=""
|
|
||||||
PCF=""
|
|
||||||
BIT=""
|
|
||||||
OUT_VERILOG=""
|
|
||||||
OUT_PCF=""
|
|
||||||
OUT_QCF=""
|
|
||||||
|
|
||||||
while true; do
|
|
||||||
case "$1" in
|
|
||||||
-d|--device) DEVICE=$2; shift 2 ;;
|
|
||||||
-P|--part) PART=$2; shift 2 ;;
|
|
||||||
-p|--pcf) PCF=$2; shift 2 ;;
|
|
||||||
-b|--bit) BIT=$2; shift 2 ;;
|
|
||||||
-v|--out-verilog) OUT_VERILOG=$2; shift 2 ;;
|
|
||||||
-o|--out-pcf) OUT_PCF=$2; shift 2 ;;
|
|
||||||
-q|--out-qcf) OUT_QCF=$2; shift 2 ;;
|
|
||||||
--) break ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
if [ -z $DEVICE ]; then
|
|
||||||
echo "Please provide device name"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z $BIT ]; then
|
|
||||||
echo "Please provide an input bistream file name"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [[ "$DEVICE" =~ ^(ql-eos-s3|ql-pp3e)$ ]]; then
|
|
||||||
echo "ERROR: Unsupported device '${DEVICE}' for fasm2bels"
|
|
||||||
exit -1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# $DEVICE is not ql-eos-s3 or ql-pp3e
|
|
||||||
if ! [[ "$DEVICE" =~ ^(ql-eos-s3|ql-pp3e)$ ]]; then
|
|
||||||
echo "ERROR: Unsupported device '${DEVICE}' for fasm2bels"
|
|
||||||
exit -1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -z "{PCF}" ]; then
|
|
||||||
PCF_ARGS="--input-pcf ${PCF}"
|
|
||||||
else
|
|
||||||
PCF_ARGS=""
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Running fasm2bels"
|
|
||||||
|
|
||||||
echo "Running fasm2bels"
|
|
||||||
`which python3` "`readlink -f ${SHARE_DIR_PATH}/scripts/fasm2bels.py`" "${BIT}" \
|
|
||||||
--phy-db "`readlink -f ${SHARE_DIR_PATH}/arch/${DEVICE}_wlcsp/db_phy.pickle`" \
|
|
||||||
--device-name "${DEVICE/ql-/}" \
|
|
||||||
--package-name "$PART" \
|
|
||||||
--input-type bitstream \
|
|
||||||
--output-verilog "${OUT_VERILOG:-$BIT.v}" \
|
|
||||||
${PCF_ARGS} \
|
|
||||||
--output-pcf "${OUT_PCF:-$BIT.v.pcf}" \
|
|
||||||
--output-qcf "${OUT_QCF:-$BIT.v.qcf}"
|
|
Loading…
Reference in New Issue