-
Notifications
You must be signed in to change notification settings - Fork 71
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Implement power saving primitive BANDGAP
As the board on the GW1N-1 chip becomes a rarity, its replacement is the Tangnano1k board with the GW1NZ-1 chip. This chip has a unique mechanism for turning off power to important things such as OSC, PLL, etc. Here we introduce a primitive that allows energy saving to be controlled dynamically. Nextpnr will add this primitive automatically if we do not use it explicitly - this is done to explicitly connect the control input since its default connection is neither VCC nor GND. BANDGAP only has an input, but does not have a fuse - it is on all the time. Of course, a reasonable question arises - what are these magic numbers in line 2258-2259 of gowin_pack.py? I really don’t want to consider these BANDGAP fuses precisely because this primitive is not configurable - and these bits are fuses that appear in the db.shortval[49]['unknown_75'] and db.logicinfo['unknown_74'] tables , which clearly describe something with decent configuration capabilities. This could be some kind of adjustable voltage stabilizer, which has an input MUX for control signals and one of the combinations connects BANDGAP. But this is not part of BANDGAP and I think I'll leave it as it is. Signed-off-by: YRabbit <[email protected]>
- Loading branch information
Showing
3 changed files
with
63 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
module top ( | ||
input key_i, | ||
output [`LEDS_NR-1:0] led | ||
); | ||
|
||
wire clk; | ||
|
||
`ifdef OSC_TYPE_OSC | ||
OSC osc( | ||
.OSCOUT(clk) | ||
); | ||
`elsif OSC_TYPE_OSCZ | ||
OSCZ osc( | ||
.OSCEN(1'b1), | ||
.OSCOUT(clk) | ||
); | ||
`elsif OSC_TYPE_OSCF | ||
OSCF osc( | ||
.OSCEN(1'b1), | ||
.OSCOUT(clk), | ||
.OSCOUT30M() | ||
); | ||
`elsif OSC_TYPE_OSCH | ||
OSCH osc( | ||
.OSCOUT(clk) | ||
); | ||
`endif | ||
defparam osc.FREQ_DIV=16; | ||
|
||
wire key = key_i ^ `INV_BTN; | ||
|
||
reg [25:0] ctr_q; | ||
wire [25:0] ctr_d; | ||
|
||
// Sequential code (flip-flop) | ||
always @(posedge clk) begin | ||
ctr_q <= ctr_d; | ||
end | ||
|
||
BANDGAP bandgap( | ||
.BGEN(key) | ||
); | ||
|
||
|
||
// Combinational code (boolean logic) | ||
assign ctr_d = ctr_q + 1'b1; | ||
assign led = {ctr_q[25:25-(`LEDS_NR - 2)], |ctr_q[25-(`LEDS_NR - 1):25-(`LEDS_NR)] }; | ||
|
||
endmodule |