OpenCores
URL https://opencores.org/ocsvn/raptor64/raptor64/trunk

Subversion Repositories raptor64

[/] [raptor64/] [trunk/] [rtl/] [verilog/] [lib/] [rolx1.v] - Blame information for rev 45

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 3 robfinch
//=============================================================================
2
//      (C) 2006-2011  Robert Finch
3
//      All rights reserved.
4
//      robfinch@opencores.org
5
//
6
//      rolx1.v
7
//              Rotate or shift to the left by zero, one, two or
8
//      three bits.
9
//
10
//
11
//
12
// This source file is free software: you can redistribute it and/or modify 
13
// it under the terms of the GNU Lesser General Public License as published 
14
// by the Free Software Foundation, either version 3 of the License, or     
15
// (at your option) any later version.                                      
16
//                                                                          
17
// This source file is distributed in the hope that it will be useful,      
18
// but WITHOUT ANY WARRANTY; without even the implied warranty of           
19
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the            
20
// GNU General Public License for more details.                             
21
//                                                                          
22
// You should have received a copy of the GNU General Public License        
23
// along with this program.  If not, see <http://www.gnu.org/licenses/>.    
24
//                                                                          
25
//      Funnel rotater / shifter
26
//      Rotate, arithmetic shift left, or logical shift /
27
//      arithmetic shift right by 0 to 63 bits.
28
//      Parameterized with a default width of 32 bits.
29
//
30
//
31
//      Rotate or shift left by 0 to 3 bits.
32
//      Parameterized with a default width of 32 bits.
33
//
34
//      Resource Usage Samples:
35
//      Ref. SpartanII
36
//      64 LUTs
37
//      
38
//      Webpack 7.1i xc3s1000-4ft256
39
//      64 LUTs / 32 slices / 11 ns             (32 bits)
40
//=============================================================================
41
//
42
module rolx1
43
#(parameter WID = 32)
44
(
45
input op,                                       // 0=shift, 1= rotate
46
input [WID:1] a,
47
input [1:0] b,
48
output reg [WID:1] o
49
);
50
wire [2:0] opx = {3{op}};
51
always @(a, b, opx)
52
begin
53
        case(b)
54
        2'd0:   o <= a;
55
        2'd1:   o <= {a[WID-1:1],a[WID]&opx[0]};
56
        2'd2:   o <= {a[WID-2:1],a[WID:WID-1]&opx[1:0]};
57
        2'd3:   o <= {a[WID-3:1],a[WID:WID-2]&opx[2:0]};
58
        endcase
59
end
60
 
61
endmodule

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.