ieee754fpu.git
5 years agotemporary ~pbs
Luke Kenneth Casson Leighton [Mon, 19 Aug 2019 14:28:21 +0000 (15:28 +0100)]
temporary ~pbs

5 years agoname LSBNotTerm submodules after bitwidth
Luke Kenneth Casson Leighton [Mon, 19 Aug 2019 11:25:38 +0000 (12:25 +0100)]
name LSBNotTerm submodules after bitwidth

5 years agouse new split-out LSBNotTerm module
Luke Kenneth Casson Leighton [Mon, 19 Aug 2019 11:22:09 +0000 (12:22 +0100)]
use new split-out LSBNotTerm module

5 years agosplit out LSB and neg term to separate module
Luke Kenneth Casson Leighton [Mon, 19 Aug 2019 11:00:41 +0000 (12:00 +0100)]
split out LSB and neg term to separate module

5 years agodocstrings, fix syntax
Luke Kenneth Casson Leighton [Mon, 19 Aug 2019 10:39:56 +0000 (11:39 +0100)]
docstrings, fix syntax

5 years agoexplain Part module
Luke Kenneth Casson Leighton [Mon, 19 Aug 2019 06:55:43 +0000 (07:55 +0100)]
explain Part module

5 years agoadd module docstrings to (new) multiply classes
Luke Kenneth Casson Leighton [Mon, 19 Aug 2019 06:34:36 +0000 (07:34 +0100)]
add module docstrings to (new) multiply classes

5 years agorename fo submodule to "finalout"
Luke Kenneth Casson Leighton [Mon, 19 Aug 2019 05:19:41 +0000 (06:19 +0100)]
rename fo submodule to "finalout"

5 years agonope - yosys graph not efficient enough
Luke Kenneth Casson Leighton [Sun, 18 Aug 2019 16:25:36 +0000 (17:25 +0100)]
nope - yosys graph not efficient enough

5 years agouse switch instead of mux, more obvious what is happening
Luke Kenneth Casson Leighton [Sun, 18 Aug 2019 16:12:04 +0000 (17:12 +0100)]
use switch instead of mux, more obvious what is happening

5 years agoadd comment about simulation bugs
Luke Kenneth Casson Leighton [Sun, 18 Aug 2019 05:29:21 +0000 (06:29 +0100)]
add comment about simulation bugs

5 years agoRevert "make variables local"
Luke Kenneth Casson Leighton [Sun, 18 Aug 2019 05:27:10 +0000 (06:27 +0100)]
Revert "make variables local"

This reverts commit e8e8c93b4f3b07fce27558460021fa62b076d9ad.

horrible nmigen simulation bug

5 years agoadd TODO code, needs sorting
Luke Kenneth Casson Leighton [Sun, 18 Aug 2019 05:25:32 +0000 (06:25 +0100)]
add TODO code, needs sorting

5 years agomerge Term into ProductTerm
Luke Kenneth Casson Leighton [Sun, 18 Aug 2019 05:02:05 +0000 (06:02 +0100)]
merge Term into ProductTerm

5 years agomake variables local
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 18:45:17 +0000 (19:45 +0100)]
make variables local

5 years agoargh horrible nmigen bug on use of sync involving modules
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 17:06:29 +0000 (18:06 +0100)]
argh horrible nmigen bug on use of sync involving modules

5 years agoweird bug - some rename experiments
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 16:54:04 +0000 (17:54 +0100)]
weird bug - some rename experiments

5 years agoFinalOutput module
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 16:26:01 +0000 (17:26 +0100)]
FinalOutput module

5 years agorename variables
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 14:58:47 +0000 (15:58 +0100)]
rename variables

5 years agoput signs through Signs module
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 14:54:04 +0000 (15:54 +0100)]
put signs through Signs module

5 years agomove local variables
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 14:30:38 +0000 (15:30 +0100)]
move local variables

5 years agoremove redundant code
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 14:23:13 +0000 (15:23 +0100)]
remove redundant code

5 years agoor data together through a module (reduce top-level complexity)
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 14:19:04 +0000 (15:19 +0100)]
or data together through a module (reduce top-level complexity)

5 years agocreate array of ProductTerms - reduces graphviz MASSIVELY
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 13:57:02 +0000 (14:57 +0100)]
create array of ProductTerms - reduces graphviz MASSIVELY

5 years agomove intermediate output to new module
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 13:29:22 +0000 (14:29 +0100)]
move intermediate output to new module

5 years agodelayed_part_ops is a local
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 12:59:39 +0000 (13:59 +0100)]
delayed_part_ops is a local

5 years agoadd name to Term output
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 12:56:19 +0000 (13:56 +0100)]
add name to Term output

5 years agomove bit selection into ProductTerms: simplifies graph
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 12:51:10 +0000 (13:51 +0100)]
move bit selection into ProductTerms: simplifies graph

5 years agosplit out "Parts" to separate module
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 12:33:22 +0000 (13:33 +0100)]
split out "Parts" to separate module

5 years agomove remaining 4 terms, use Term class
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 11:17:33 +0000 (12:17 +0100)]
move remaining 4 terms, use Term class

5 years agoderive new class Term and ProductTerm
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 11:05:04 +0000 (12:05 +0100)]
derive new class Term and ProductTerm

5 years agouse Cat (again) on intermediate values
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 10:48:58 +0000 (11:48 +0100)]
use Cat (again) on intermediate values

5 years agosimplify sign/term bits using Cat
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 10:32:15 +0000 (11:32 +0100)]
simplify sign/term bits using Cat

5 years agomove product terms to separate module (Term)
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 10:13:59 +0000 (11:13 +0100)]
move product terms to separate module (Term)

5 years agoadd new Terms class, get part_pts into intermediary
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 09:57:23 +0000 (10:57 +0100)]
add new Terms class, get part_pts into intermediary

5 years agopart replaced by bit_select
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 09:11:34 +0000 (10:11 +0100)]
part replaced by bit_select

5 years agowhoops, a-enabled and b-enabled swapped
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 08:41:41 +0000 (09:41 +0100)]
whoops, a-enabled and b-enabled swapped

5 years agostash intermediaries for output into temp signals
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 08:24:20 +0000 (09:24 +0100)]
stash intermediaries for output into temp signals

5 years agoassignment in Cat wrong way round
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 08:13:28 +0000 (09:13 +0100)]
assignment in Cat wrong way round

5 years agouse reset_less
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 08:07:36 +0000 (09:07 +0100)]
use reset_less

5 years agowhoops use already-used list
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 08:02:32 +0000 (09:02 +0100)]
whoops use already-used list

5 years agoboolean logic inversion, x = ~a & ~b & ~c ==> ~(a | b | c) then use list
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 08:00:18 +0000 (09:00 +0100)]
boolean logic inversion, x = ~a & ~b & ~c ==> ~(a | b | c) then use list
of terms, use bool(), and graph size is reduced

5 years agoconcatenate parts using list then Cat() - again, simplifies output
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 07:49:23 +0000 (08:49 +0100)]
concatenate parts using list then Cat() - again, simplifies output

5 years agoa_enabled and b_enabled into signals
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 07:40:34 +0000 (08:40 +0100)]
a_enabled and b_enabled into signals

5 years agoadd intermediate values as signals
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 07:31:24 +0000 (08:31 +0100)]
add intermediate values as signals

5 years agomove variable to pyi file
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 07:17:24 +0000 (08:17 +0100)]
move variable to pyi file

5 years agostore mask in intermediary
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 07:14:10 +0000 (08:14 +0100)]
store mask in intermediary

5 years agouse Cat instead of for-loops: cleans up the yosys graphviz massively
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 07:06:20 +0000 (08:06 +0100)]
use Cat instead of for-loops: cleans up the yosys graphviz massively

5 years agomove typing to multiplier.pyi
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 06:56:20 +0000 (07:56 +0100)]
move typing to multiplier.pyi

5 years agoadd partitioned multiplier/adder
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 06:45:18 +0000 (07:45 +0100)]
add partitioned multiplier/adder

5 years agorename fp div classes and submodule
Luke Kenneth Casson Leighton [Sat, 17 Aug 2019 04:24:38 +0000 (05:24 +0100)]
rename fp div classes and submodule

5 years agotest flipping of latchable pipeline stage between sync and comb modes
Luke Kenneth Casson Leighton [Fri, 16 Aug 2019 10:24:40 +0000 (11:24 +0100)]
test flipping of latchable pipeline stage between sync and comb modes

5 years agoupdate comments
Luke Kenneth Casson Leighton [Fri, 16 Aug 2019 03:38:00 +0000 (04:38 +0100)]
update comments

5 years agoset up data in temporaries correctly
Luke Kenneth Casson Leighton [Thu, 15 Aug 2019 17:23:12 +0000 (18:23 +0100)]
set up data in temporaries correctly

5 years agoupdate MaskCancellable docstrings
Luke Kenneth Casson Leighton [Thu, 15 Aug 2019 16:57:05 +0000 (17:57 +0100)]
update MaskCancellable docstrings

5 years agoadd dynamic comb/sync mode to MaskCancellable
Luke Kenneth Casson Leighton [Thu, 15 Aug 2019 16:51:20 +0000 (17:51 +0100)]
add dynamic comb/sync mode to MaskCancellable

5 years agowhitespace
Luke Kenneth Casson Leighton [Thu, 15 Aug 2019 14:26:32 +0000 (15:26 +0100)]
whitespace

5 years agodebugging feedback pipe
Luke Kenneth Casson Leighton [Wed, 14 Aug 2019 13:39:10 +0000 (14:39 +0100)]
debugging feedback pipe

5 years agofix syntax errors in fmac conversion
Luke Kenneth Casson Leighton [Mon, 12 Aug 2019 02:25:14 +0000 (03:25 +0100)]
fix syntax errors in fmac conversion

5 years agoincrease number of fpmul operands to 3
Luke Kenneth Casson Leighton [Sun, 11 Aug 2019 12:35:24 +0000 (13:35 +0100)]
increase number of fpmul operands to 3

5 years agorestore old Multi-in/out behaviour
Luke Kenneth Casson Leighton [Sun, 11 Aug 2019 12:34:54 +0000 (13:34 +0100)]
restore old Multi-in/out behaviour

5 years agostart converting hardfloat-verilog fmac to nmigen
Luke Kenneth Casson Leighton [Sun, 11 Aug 2019 07:42:47 +0000 (08:42 +0100)]
start converting hardfloat-verilog fmac to nmigen

5 years agostart converting hardfloat-verilog fmac to nmigen
Luke Kenneth Casson Leighton [Sun, 11 Aug 2019 06:01:00 +0000 (07:01 +0100)]
start converting hardfloat-verilog fmac to nmigen

5 years agostart converting hardfloat-verilog fmac to nmigen
Luke Kenneth Casson Leighton [Sat, 10 Aug 2019 11:59:48 +0000 (12:59 +0100)]
start converting hardfloat-verilog fmac to nmigen

5 years ago{x}{y} in verilog means x occurrences of y
Luke Kenneth Casson Leighton [Sat, 10 Aug 2019 10:58:19 +0000 (11:58 +0100)]
{x}{y} in verilog means x occurrences of y

5 years ago{x}{y} in verilog means x occurrences of y
Luke Kenneth Casson Leighton [Sat, 10 Aug 2019 10:18:09 +0000 (11:18 +0100)]
{x}{y} in verilog means x occurrences of y

5 years agostart converting hardfloat-verilog fmac to nmigen
Luke Kenneth Casson Leighton [Sat, 10 Aug 2019 07:53:28 +0000 (08:53 +0100)]
start converting hardfloat-verilog fmac to nmigen

5 years agostart converting hardfloat-verilog fmac to nmigen
Luke Kenneth Casson Leighton [Sat, 10 Aug 2019 06:29:09 +0000 (07:29 +0100)]
start converting hardfloat-verilog fmac to nmigen

5 years agoroute-back experimentation
Luke Kenneth Casson Leighton [Wed, 7 Aug 2019 11:26:13 +0000 (12:26 +0100)]
route-back experimentation

5 years agoadd experimental feedback pipe test
Luke Kenneth Casson Leighton [Wed, 7 Aug 2019 02:20:56 +0000 (03:20 +0100)]
add experimental feedback pipe test

5 years agorespect Ready/Valid signalling (stall capability) in MaskCancellable
Luke Kenneth Casson Leighton [Wed, 7 Aug 2019 00:15:16 +0000 (01:15 +0100)]
respect Ready/Valid signalling (stall capability) in MaskCancellable

this will be needed for pipeline bypassing

5 years agoadd mask cancellation to FPDIV and to fpmux unit test
Luke Kenneth Casson Leighton [Tue, 6 Aug 2019 11:19:33 +0000 (12:19 +0100)]
add mask cancellation to FPDIV and to fpmux unit test

5 years agomultiply mask width for concurrent pipeline
Luke Kenneth Casson Leighton [Mon, 5 Aug 2019 07:37:13 +0000 (08:37 +0100)]
multiply mask width for concurrent pipeline

5 years agohack to set predicate mask (if it exists)
Luke Kenneth Casson Leighton [Mon, 5 Aug 2019 07:36:41 +0000 (08:36 +0100)]
hack to set predicate mask (if it exists)

5 years agowhoops inherit from MaskCancellable not SimpleHandshake
Luke Kenneth Casson Leighton [Mon, 5 Aug 2019 07:36:11 +0000 (08:36 +0100)]
whoops inherit from MaskCancellable not SimpleHandshake

5 years agoadded maskwidth and dynamic use of MaskCancellable, no "bugs", still to
Luke Kenneth Casson Leighton [Sun, 4 Aug 2019 11:34:38 +0000 (12:34 +0100)]
added maskwidth and dynamic use of MaskCancellable, no "bugs", still to
confirm if it works

5 years agoonly pass on the uncancelled mask bits
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 22:39:12 +0000 (23:39 +0100)]
only pass on the uncancelled mask bits

5 years agotest actual cancellation mask (works)
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 22:29:54 +0000 (23:29 +0100)]
test actual cancellation mask (works)

5 years agoadd 2 extra stages to cancel test
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 21:29:32 +0000 (22:29 +0100)]
add 2 extra stages to cancel test

5 years agogive names to muxer submodules
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 09:49:31 +0000 (10:49 +0100)]
give names to muxer submodules

5 years agopass on stop bits as well
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 09:38:51 +0000 (10:38 +0100)]
pass on stop bits as well

5 years agoconcatenate mask bits on fan-in, split on fan-out
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 09:28:37 +0000 (10:28 +0100)]
concatenate mask bits on fan-in, split on fan-out

5 years agoadd maskable in/out cancellable test
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 05:17:26 +0000 (06:17 +0100)]
add maskable in/out cancellable test

5 years agoadd in cancelmask
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 04:37:40 +0000 (05:37 +0100)]
add in cancelmask

5 years agoexplain comments
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 01:19:51 +0000 (02:19 +0100)]
explain comments

5 years agogenerate mask il
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 01:10:04 +0000 (02:10 +0100)]
generate mask il

5 years agomask sort-of working as long as "ready" is always true
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 01:06:22 +0000 (02:06 +0100)]
mask sort-of working as long as "ready" is always true

5 years agoadd mask to NextControl
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 00:38:09 +0000 (01:38 +0100)]
add mask to NextControl

5 years agoadd mask to PrevControl
Luke Kenneth Casson Leighton [Sat, 3 Aug 2019 00:32:42 +0000 (01:32 +0100)]
add mask to PrevControl

5 years agoadd first draft MaskCancellable pipe class
Luke Kenneth Casson Leighton [Fri, 2 Aug 2019 00:50:40 +0000 (01:50 +0100)]
add first draft MaskCancellable pipe class

5 years agoupdate to nmutil Memory API
Luke Kenneth Casson Leighton [Fri, 2 Aug 2019 00:50:22 +0000 (01:50 +0100)]
update to nmutil Memory API

5 years agoupdate test
Luke Kenneth Casson Leighton [Fri, 2 Aug 2019 00:49:55 +0000 (01:49 +0100)]
update test

5 years agowhitespace
Luke Kenneth Casson Leighton [Thu, 1 Aug 2019 22:54:52 +0000 (23:54 +0100)]
whitespace

5 years agomove priority picker from soc to nmutil
Luke Kenneth Casson Leighton [Thu, 1 Aug 2019 07:48:29 +0000 (08:48 +0100)]
move priority picker from soc to nmutil

5 years agoadd copy of inout mux pipe
Luke Kenneth Casson Leighton [Thu, 1 Aug 2019 07:42:16 +0000 (08:42 +0100)]
add copy of inout mux pipe

5 years agowhitespace
Luke Kenneth Casson Leighton [Thu, 1 Aug 2019 07:41:31 +0000 (08:41 +0100)]
whitespace

5 years agowhitespace
Luke Kenneth Casson Leighton [Thu, 1 Aug 2019 01:35:28 +0000 (02:35 +0100)]
whitespace

5 years agoremove more redundant modules
Luke Kenneth Casson Leighton [Thu, 1 Aug 2019 01:35:15 +0000 (02:35 +0100)]
remove more redundant modules

5 years agocomment; remove unneeded code
Luke Kenneth Casson Leighton [Thu, 1 Aug 2019 01:25:37 +0000 (02:25 +0100)]
comment; remove unneeded code

5 years agoremove i_specfn and o_specfn from FP*MuxInOut, use self.alu.ispec() and ospec()
Luke Kenneth Casson Leighton [Thu, 1 Aug 2019 01:23:10 +0000 (02:23 +0100)]
remove i_specfn and o_specfn from FP*MuxInOut, use self.alu.ispec() and ospec()

every class has an alu object, the pipe specs are the same for all use-cases
so....