aboutsummaryrefslogtreecommitdiff
path: root/Buffer.bsv
blob: b44931b71a085494c7c8c598609ecac0cafb0cd7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// Copyright (C) 2015 Benjamin Barenblat <bbaren@mit.edu>
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
// FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
// details.
//
// You should have received a copy of the GNU General Public License along with
// this program.  If not, see <http://www.gnu.org/licenses/>.


interface BufferBank;
   (* always_ready *)
   method Bit#(8) led();

   (* always_enabled, always_ready *)
   method Action update(Bit#(8) switch);
endinterface

(* synthesize *)
module mkBufferBank(BufferBank);
   Wire#(Bit#(8)) w <- mkDWire(minBound);

   method Bit#(8) led();
      return w;
   endmethod

   method Action update(switch);
      w <= switch;
   endmethod
endmodule