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

Subversion Repositories can

[/] [can/] [trunk/] [rtl/] [verilog/] [can_registers.v] - Blame information for rev 70

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

Line No. Rev Author Line
1 66 mohor
//////////////////////////////////////////////////////////////////////
2
////                                                              ////
3
////  can_registers.v                                             ////
4
////                                                              ////
5
////                                                              ////
6
////  This file is part of the CAN Protocol Controller            ////
7
////  http://www.opencores.org/projects/can/                      ////
8
////                                                              ////
9
////                                                              ////
10
////  Author(s):                                                  ////
11
////       Igor Mohor                                             ////
12
////       igorm@opencores.org                                    ////
13
////                                                              ////
14
////                                                              ////
15
////  All additional information is available in the README.txt   ////
16
////  file.                                                       ////
17
////                                                              ////
18
//////////////////////////////////////////////////////////////////////
19
////                                                              ////
20
//// Copyright (C) 2002, 2003 Authors                             ////
21
////                                                              ////
22
//// This source file may be used and distributed without         ////
23
//// restriction provided that this copyright statement is not    ////
24
//// removed from the file and that any derivative work contains  ////
25
//// the original copyright notice and the associated disclaimer. ////
26
////                                                              ////
27
//// This source file is free software; you can redistribute it   ////
28
//// and/or modify it under the terms of the GNU Lesser General   ////
29
//// Public License as published by the Free Software Foundation; ////
30
//// either version 2.1 of the License, or (at your option) any   ////
31
//// later version.                                               ////
32
////                                                              ////
33
//// This source is distributed in the hope that it will be       ////
34
//// useful, but WITHOUT ANY WARRANTY; without even the implied   ////
35
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      ////
36
//// PURPOSE.  See the GNU Lesser General Public License for more ////
37
//// details.                                                     ////
38
////                                                              ////
39
//// You should have received a copy of the GNU Lesser General    ////
40
//// Public License along with this source; if not, download it   ////
41
//// from http://www.opencores.org/lgpl.shtml                     ////
42
////                                                              ////
43
//// The CAN protocol is developed by Robert Bosch GmbH and       ////
44
//// protected by patents. Anybody who wants to implement this    ////
45
//// CAN IP core on silicon has to obtain a CAN protocol license  ////
46
//// from Bosch.                                                  ////
47
////                                                              ////
48
//////////////////////////////////////////////////////////////////////
49
//
50
// CVS Revision History
51
//
52
// $Log: not supported by cvs2svn $
53 70 mohor
// Revision 1.23  2003/04/15 15:31:24  mohor
54
// Some features are supported in extended mode only (listen_only_mode...).
55
//
56 69 mohor
// Revision 1.22  2003/03/20 16:58:50  mohor
57
// unix.
58
//
59 66 mohor
// Revision 1.20  2003/03/11 16:31:05  mohor
60
// Mux used for clkout to avoid "gated clocks warning".
61
//
62
// Revision 1.19  2003/03/10 17:34:25  mohor
63
// Doubled declarations removed.
64
//
65
// Revision 1.18  2003/03/01 22:52:11  mohor
66
// Data is latched on read.
67
//
68
// Revision 1.17  2003/02/19 15:09:02  mohor
69
// Incomplete sensitivity list fixed.
70
//
71
// Revision 1.16  2003/02/19 14:44:03  mohor
72
// CAN core finished. Host interface added. Registers finished.
73
// Synchronization to the wishbone finished.
74
//
75
// Revision 1.15  2003/02/18 00:10:15  mohor
76
// Most of the registers added. Registers "arbitration lost capture", "error code
77
// capture" + few more still need to be added.
78
//
79
// Revision 1.14  2003/02/14 20:17:01  mohor
80
// Several registers added. Not finished, yet.
81
//
82
// Revision 1.13  2003/02/12 14:25:30  mohor
83
// abort_tx added.
84
//
85
// Revision 1.12  2003/02/11 00:56:06  mohor
86
// Wishbone interface added.
87
//
88
// Revision 1.11  2003/02/09 02:24:33  mohor
89
// Bosch license warning added. Error counters finished. Overload frames
90
// still need to be fixed.
91
//
92
// Revision 1.10  2003/01/31 01:13:38  mohor
93
// backup.
94
//
95
// Revision 1.9  2003/01/15 13:16:48  mohor
96
// When a frame with "remote request" is received, no data is stored
97
// to fifo, just the frame information (identifier, ...). Data length
98
// that is stored is the received data length and not the actual data
99
// length that is stored to fifo.
100
//
101
// Revision 1.8  2003/01/14 17:25:09  mohor
102
// Addresses corrected to decimal values (previously hex).
103
//
104
// Revision 1.7  2003/01/14 12:19:35  mohor
105
// rx_fifo is now working.
106
//
107
// Revision 1.6  2003/01/10 17:51:34  mohor
108
// Temporary version (backup).
109
//
110
// Revision 1.5  2003/01/09 14:46:58  mohor
111
// Temporary files (backup).
112
//
113
// Revision 1.4  2003/01/08 02:10:55  mohor
114
// Acceptance filter added.
115
//
116
// Revision 1.3  2002/12/27 00:12:52  mohor
117
// Header changed, testbench improved to send a frame (crc still missing).
118
//
119
// Revision 1.2  2002/12/26 16:00:34  mohor
120
// Testbench define file added. Clock divider register added.
121
//
122
// Revision 1.1.1.1  2002/12/20 16:39:21  mohor
123
// Initial
124
//
125
//
126
//
127
 
128
// synopsys translate_off
129
`include "timescale.v"
130
// synopsys translate_on
131
`include "can_defines.v"
132
 
133
module can_registers
134
(
135
  clk,
136
  rst,
137
  cs,
138
  we,
139
  addr,
140
  data_in,
141
  data_out,
142
  irq,
143
 
144
  sample_point,
145
  transmitting,
146
  set_reset_mode,
147
  node_bus_off,
148
  error_status,
149
  rx_err_cnt,
150
  tx_err_cnt,
151
  transmit_status,
152
  receive_status,
153
  tx_successful,
154
  need_to_tx,
155
  overrun,
156
  info_empty,
157
  set_bus_error_irq,
158
  set_arbitration_lost_irq,
159
  arbitration_lost_capture,
160
  node_error_passive,
161
  node_error_active,
162
  rx_message_counter,
163
 
164
 
165
  /* Mode register */
166
  reset_mode,
167
  listen_only_mode,
168
  acceptance_filter_mode,
169
  self_test_mode,
170
 
171
 
172
  /* Command register */
173
  clear_data_overrun,
174
  release_buffer,
175
  abort_tx,
176
  tx_request,
177
  self_rx_request,
178
  single_shot_transmission,
179
 
180
  /* Arbitration Lost Capture Register */
181
  read_arbitration_lost_capture_reg,
182
 
183
  /* Error Code Capture Register */
184
  read_error_code_capture_reg,
185
  error_capture_code,
186
 
187
  /* Bus Timing 0 register */
188
  baud_r_presc,
189
  sync_jump_width,
190
 
191
  /* Bus Timing 1 register */
192
  time_segment1,
193
  time_segment2,
194
  triple_sampling,
195
 
196
  /* Error Warning Limit register */
197
  error_warning_limit,
198
 
199
  /* Rx Error Counter register */
200
  we_rx_err_cnt,
201
 
202
  /* Tx Error Counter register */
203
  we_tx_err_cnt,
204
 
205
  /* Clock Divider register */
206
  extended_mode,
207
  clkout,
208
 
209
 
210
  /* This section is for BASIC and EXTENDED mode */
211
  /* Acceptance code register */
212
  acceptance_code_0,
213
 
214
  /* Acceptance mask register */
215
  acceptance_mask_0,
216
  /* End: This section is for BASIC and EXTENDED mode */
217
 
218
  /* This section is for EXTENDED mode */
219
  /* Acceptance code register */
220
  acceptance_code_1,
221
  acceptance_code_2,
222
  acceptance_code_3,
223
 
224
  /* Acceptance mask register */
225
  acceptance_mask_1,
226
  acceptance_mask_2,
227
  acceptance_mask_3,
228
  /* End: This section is for EXTENDED mode */
229
 
230
  /* Tx data registers. Holding identifier (basic mode), tx frame information (extended mode) and data */
231
  tx_data_0,
232
  tx_data_1,
233
  tx_data_2,
234
  tx_data_3,
235
  tx_data_4,
236
  tx_data_5,
237
  tx_data_6,
238
  tx_data_7,
239
  tx_data_8,
240
  tx_data_9,
241
  tx_data_10,
242
  tx_data_11,
243
  tx_data_12
244
  /* End: Tx data registers */
245
 
246
 
247
 
248
 
249
);
250
 
251
parameter Tp = 1;
252
 
253
input         clk;
254
input         rst;
255
input         cs;
256
input         we;
257
input   [7:0] addr;
258
input   [7:0] data_in;
259
 
260
output  [7:0] data_out;
261
reg     [7:0] data_out;
262
 
263
output        irq;
264
 
265
input         sample_point;
266
input         transmitting;
267
input         set_reset_mode;
268
input         node_bus_off;
269
input         error_status;
270
input   [7:0] rx_err_cnt;
271
input   [7:0] tx_err_cnt;
272
input         transmit_status;
273
input         receive_status;
274
input         tx_successful;
275
input         need_to_tx;
276
input         overrun;
277
input         info_empty;
278
input         set_bus_error_irq;
279
input         set_arbitration_lost_irq;
280
input   [4:0] arbitration_lost_capture;
281
input         node_error_passive;
282
input         node_error_active;
283
input   [6:0] rx_message_counter;
284
 
285
 
286
 
287
/* Mode register */
288
output        reset_mode;
289
output        listen_only_mode;
290
output        acceptance_filter_mode;
291
output        self_test_mode;
292
 
293
/* Command register */
294
output        clear_data_overrun;
295
output        release_buffer;
296
output        abort_tx;
297
output        tx_request;
298
output        self_rx_request;
299
output        single_shot_transmission;
300
 
301
/* Arbitration Lost Capture Register */
302
output        read_arbitration_lost_capture_reg;
303
 
304
/* Error Code Capture Register */
305
output        read_error_code_capture_reg;
306
input   [7:0] error_capture_code;
307
 
308
/* Bus Timing 0 register */
309
output  [5:0] baud_r_presc;
310
output  [1:0] sync_jump_width;
311
 
312
 
313
/* Bus Timing 1 register */
314
output  [3:0] time_segment1;
315
output  [2:0] time_segment2;
316
output        triple_sampling;
317
 
318
/* Error Warning Limit register */
319
output  [7:0] error_warning_limit;
320
 
321
/* Rx Error Counter register */
322
output        we_rx_err_cnt;
323
 
324
/* Tx Error Counter register */
325
output        we_tx_err_cnt;
326
 
327
/* Clock Divider register */
328
output        extended_mode;
329
output        clkout;
330
 
331
 
332
/* This section is for BASIC and EXTENDED mode */
333
/* Acceptance code register */
334
output  [7:0] acceptance_code_0;
335
 
336
/* Acceptance mask register */
337
output  [7:0] acceptance_mask_0;
338
 
339
/* End: This section is for BASIC and EXTENDED mode */
340
 
341
 
342
/* This section is for EXTENDED mode */
343
/* Acceptance code register */
344
output  [7:0] acceptance_code_1;
345
output  [7:0] acceptance_code_2;
346
output  [7:0] acceptance_code_3;
347
 
348
/* Acceptance mask register */
349
output  [7:0] acceptance_mask_1;
350
output  [7:0] acceptance_mask_2;
351
output  [7:0] acceptance_mask_3;
352
 
353
/* End: This section is for EXTENDED mode */
354
 
355
/* Tx data registers. Holding identifier (basic mode), tx frame information (extended mode) and data */
356
output  [7:0] tx_data_0;
357
output  [7:0] tx_data_1;
358
output  [7:0] tx_data_2;
359
output  [7:0] tx_data_3;
360
output  [7:0] tx_data_4;
361
output  [7:0] tx_data_5;
362
output  [7:0] tx_data_6;
363
output  [7:0] tx_data_7;
364
output  [7:0] tx_data_8;
365
output  [7:0] tx_data_9;
366
output  [7:0] tx_data_10;
367
output  [7:0] tx_data_11;
368
output  [7:0] tx_data_12;
369
/* End: Tx data registers */
370
 
371
 
372
reg           tx_successful_q;
373
reg           overrun_q;
374
reg           overrun_status;
375
reg           transmission_complete;
376
reg           transmit_buffer_status_q;
377
reg           receive_buffer_status;
378
reg           info_empty_q;
379
reg           error_status_q;
380
reg           node_bus_off_q;
381
reg           node_error_passive_q;
382
reg           transmit_buffer_status;
383
reg           single_shot_transmission;
384
 
385
 
386
// Some interrupts exist in basic mode and in extended mode. Since they are in different registers they need to be multiplexed.
387
wire          data_overrun_irq_en;
388
wire          error_warning_irq_en;
389
wire          transmit_irq_en;
390
wire          receive_irq_en;
391
 
392
wire    [7:0] irq_reg;
393
 
394
wire we_mode                  = cs & we & (addr == 8'd0);
395
wire we_command               = cs & we & (addr == 8'd1);
396
wire we_bus_timing_0          = cs & we & (addr == 8'd6) & reset_mode;
397
wire we_bus_timing_1          = cs & we & (addr == 8'd7) & reset_mode;
398
wire we_clock_divider_low     = cs & we & (addr == 8'd31);
399
wire we_clock_divider_hi      = we_clock_divider_low & reset_mode;
400
 
401
wire read = cs & (~we);
402
wire read_irq_reg = read & (addr == 8'd3);
403
assign read_arbitration_lost_capture_reg = read & extended_mode & (addr == 8'd11);
404
assign read_error_code_capture_reg = read & extended_mode & (addr == 8'd12);
405
 
406
/* This section is for BASIC and EXTENDED mode */
407
wire we_acceptance_code_0       = cs & we &   reset_mode  & ((~extended_mode) & (addr == 8'd4)  | extended_mode & (addr == 8'd16));
408
wire we_acceptance_mask_0       = cs & we &   reset_mode  & ((~extended_mode) & (addr == 8'd5)  | extended_mode & (addr == 8'd20));
409
wire we_tx_data_0               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd10) | extended_mode & (addr == 8'd16)) & transmit_buffer_status;
410
wire we_tx_data_1               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd11) | extended_mode & (addr == 8'd17)) & transmit_buffer_status;
411
wire we_tx_data_2               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd12) | extended_mode & (addr == 8'd18)) & transmit_buffer_status;
412
wire we_tx_data_3               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd13) | extended_mode & (addr == 8'd19)) & transmit_buffer_status;
413
wire we_tx_data_4               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd14) | extended_mode & (addr == 8'd20)) & transmit_buffer_status;
414
wire we_tx_data_5               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd15) | extended_mode & (addr == 8'd21)) & transmit_buffer_status;
415
wire we_tx_data_6               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd16) | extended_mode & (addr == 8'd22)) & transmit_buffer_status;
416
wire we_tx_data_7               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd17) | extended_mode & (addr == 8'd23)) & transmit_buffer_status;
417
wire we_tx_data_8               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd18) | extended_mode & (addr == 8'd24)) & transmit_buffer_status;
418
wire we_tx_data_9               = cs & we & (~reset_mode) & ((~extended_mode) & (addr == 8'd19) | extended_mode & (addr == 8'd25)) & transmit_buffer_status;
419
wire we_tx_data_10              = cs & we & (~reset_mode) & (                                     extended_mode & (addr == 8'd26)) & transmit_buffer_status;
420
wire we_tx_data_11              = cs & we & (~reset_mode) & (                                     extended_mode & (addr == 8'd27)) & transmit_buffer_status;
421
wire we_tx_data_12              = cs & we & (~reset_mode) & (                                     extended_mode & (addr == 8'd28)) & transmit_buffer_status;
422
/* End: This section is for BASIC and EXTENDED mode */
423
 
424
 
425
/* This section is for EXTENDED mode */
426
wire   we_interrupt_enable      = cs & we & (addr == 8'd4)  & extended_mode;
427
wire   we_error_warning_limit   = cs & we & (addr == 8'd13) & reset_mode & extended_mode;
428
assign we_rx_err_cnt            = cs & we & (addr == 8'd14) & reset_mode & extended_mode;
429
assign we_tx_err_cnt            = cs & we & (addr == 8'd15) & reset_mode & extended_mode;
430
wire   we_acceptance_code_1     = cs & we & (addr == 8'd17) & reset_mode & extended_mode;
431
wire   we_acceptance_code_2     = cs & we & (addr == 8'd18) & reset_mode & extended_mode;
432
wire   we_acceptance_code_3     = cs & we & (addr == 8'd19) & reset_mode & extended_mode;
433
wire   we_acceptance_mask_1     = cs & we & (addr == 8'd21) & reset_mode & extended_mode;
434
wire   we_acceptance_mask_2     = cs & we & (addr == 8'd22) & reset_mode & extended_mode;
435
wire   we_acceptance_mask_3     = cs & we & (addr == 8'd23) & reset_mode & extended_mode;
436
/* End: This section is for EXTENDED mode */
437
 
438
 
439
 
440
always @ (posedge clk)
441
begin
442
  tx_successful_q           <=#Tp tx_successful;
443
  overrun_q                 <=#Tp overrun;
444
  transmit_buffer_status_q  <=#Tp transmit_buffer_status;
445
  info_empty_q              <=#Tp info_empty;
446
  error_status_q            <=#Tp error_status;
447
  node_bus_off_q            <=#Tp node_bus_off;
448
  node_error_passive_q      <=#Tp node_error_passive;
449
end
450
 
451
 
452
 
453
/* Mode register */
454
wire   [0:0] mode;
455
wire   [4:1] mode_basic;
456
wire   [3:1] mode_ext;
457
wire         receive_irq_en_basic;
458
wire         transmit_irq_en_basic;
459
wire         error_irq_en_basic;
460
wire         overrun_irq_en_basic;
461
 
462
can_register_asyn_syn #(1, 1'h1) MODE_REG0
463
( .data_in(data_in[0]),
464
  .data_out(mode[0]),
465
  .we(we_mode),
466
  .clk(clk),
467
  .rst(rst),
468
  .rst_sync(set_reset_mode)
469
);
470
 
471
can_register_asyn #(4, 0) MODE_REG_BASIC
472
( .data_in(data_in[4:1]),
473
  .data_out(mode_basic[4:1]),
474
  .we(we_mode),
475
  .clk(clk),
476
  .rst(rst)
477
);
478
 
479
can_register_asyn #(3, 0) MODE_REG_EXT
480
( .data_in(data_in[3:1]),
481
  .data_out(mode_ext[3:1]),
482
  .we(we_mode & reset_mode),
483
  .clk(clk),
484
  .rst(rst)
485
);
486
 
487
assign reset_mode             = mode[0];
488 69 mohor
assign listen_only_mode       = extended_mode & mode_ext[1];
489
assign self_test_mode         = extended_mode & mode_ext[2];
490
assign acceptance_filter_mode = extended_mode & mode_ext[3];
491 66 mohor
 
492
assign receive_irq_en_basic  = mode_basic[1];
493
assign transmit_irq_en_basic = mode_basic[2];
494
assign error_irq_en_basic    = mode_basic[3];
495
assign overrun_irq_en_basic  = mode_basic[4];
496
/* End Mode register */
497
 
498
 
499
/* Command register */
500
wire   [4:0] command;
501
can_register_asyn_syn #(1, 1'h0) COMMAND_REG0
502
( .data_in(data_in[0]),
503
  .data_out(command[0]),
504
  .we(we_command),
505
  .clk(clk),
506
  .rst(rst),
507
  .rst_sync(tx_request & sample_point)
508
);
509
 
510
can_register_asyn_syn #(1, 1'h0) COMMAND_REG1
511
( .data_in(data_in[1]),
512
  .data_out(command[1]),
513
  .we(we_command),
514
  .clk(clk),
515
  .rst(rst),
516
  .rst_sync(abort_tx & ~transmitting)
517
);
518
 
519
can_register_asyn_syn #(2, 2'h0) COMMAND_REG
520
( .data_in(data_in[3:2]),
521
  .data_out(command[3:2]),
522
  .we(we_command),
523
  .clk(clk),
524
  .rst(rst),
525
  .rst_sync(|command[3:2])
526
);
527
 
528
can_register_asyn_syn #(1, 1'h0) COMMAND_REG4
529
( .data_in(data_in[4]),
530
  .data_out(command[4]),
531
  .we(we_command),
532
  .clk(clk),
533
  .rst(rst),
534
  .rst_sync(tx_successful & (~tx_successful_q) | abort_tx)
535
);
536
 
537
assign self_rx_request = command[4] & (~command[0]);
538
assign clear_data_overrun = command[3];
539
assign release_buffer = command[2];
540
assign abort_tx = command[1] & (~command[0]) & (~command[4]);
541
assign tx_request = command[0] | command[4];
542
 
543
 
544
always @ (posedge clk or posedge rst)
545
begin
546
  if (rst)
547
    single_shot_transmission <= 1'b0;
548
  else if (we_command & data_in[1] & (data_in[1] | data_in[4]))
549
    single_shot_transmission <=#Tp 1'b1;
550
  else if (tx_successful & (~tx_successful_q))
551
    single_shot_transmission <=#Tp 1'b0;
552
end
553
 
554
 
555
 
556
/* End Command register */
557
 
558
 
559
/* Status register */
560
 
561
wire   [7:0] status;
562
 
563
assign status[7] = node_bus_off;
564
assign status[6] = error_status;
565
assign status[5] = transmit_status;
566
assign status[4] = receive_status;
567
assign status[3] = transmission_complete;
568
assign status[2] = transmit_buffer_status;
569
assign status[1] = overrun_status;
570
assign status[0] = receive_buffer_status;
571
 
572
 
573
 
574
always @ (posedge clk or posedge rst)
575
begin
576
  if (rst)
577
    transmission_complete <= 1'b1;
578
  else if (tx_successful & (~tx_successful_q) | abort_tx)
579
    transmission_complete <=#Tp 1'b1;
580
  else if (tx_request)
581
    transmission_complete <=#Tp 1'b0;
582
end
583
 
584
 
585
always @ (posedge clk or posedge rst)
586
begin
587
  if (rst)
588
    transmit_buffer_status <= 1'b1;
589
  else if (tx_request)
590
    transmit_buffer_status <=#Tp 1'b0;
591
  else if (~need_to_tx)
592
    transmit_buffer_status <=#Tp 1'b1;
593
end
594
 
595
 
596
always @ (posedge clk or posedge rst)
597
begin
598
  if (rst)
599
    overrun_status <= 1'b0;
600
  else if (overrun & (~overrun_q))
601
    overrun_status <=#Tp 1'b1;
602
  else if (clear_data_overrun)
603
    overrun_status <=#Tp 1'b0;
604
end
605
 
606
 
607
always @ (posedge clk or posedge rst)
608
begin
609
  if (rst)
610
    receive_buffer_status <= 1'b0;
611
  else if (release_buffer)
612
    receive_buffer_status <=#Tp 1'b0;
613
  else if (~info_empty)
614
    receive_buffer_status <=#Tp 1'b1;
615
end
616
 
617
/* End Status register */
618
 
619
 
620
/* Interrupt Enable register (extended mode) */
621
wire   [7:0] irq_en_ext;
622
wire         bus_error_irq_en;
623
wire         arbitration_lost_irq_en;
624
wire         error_passive_irq_en;
625
wire         data_overrun_irq_en_ext;
626
wire         error_warning_irq_en_ext;
627
wire         transmit_irq_en_ext;
628
wire         receive_irq_en_ext;
629
 
630
can_register #(8) IRQ_EN_REG
631
( .data_in(data_in),
632
  .data_out(irq_en_ext),
633
  .we(we_interrupt_enable),
634
  .clk(clk)
635
);
636
 
637
 
638
assign bus_error_irq_en             = irq_en_ext[7];
639
assign arbitration_lost_irq_en      = irq_en_ext[6];
640
assign error_passive_irq_en         = irq_en_ext[5];
641
assign data_overrun_irq_en_ext      = irq_en_ext[3];
642
assign error_warning_irq_en_ext     = irq_en_ext[2];
643
assign transmit_irq_en_ext          = irq_en_ext[1];
644
assign receive_irq_en_ext           = irq_en_ext[0];
645
/* End Bus Timing 0 register */
646
 
647
 
648
/* Bus Timing 0 register */
649
wire   [7:0] bus_timing_0;
650
can_register #(8) BUS_TIMING_0_REG
651
( .data_in(data_in),
652
  .data_out(bus_timing_0),
653
  .we(we_bus_timing_0),
654
  .clk(clk)
655
);
656
 
657
assign baud_r_presc = bus_timing_0[5:0];
658
assign sync_jump_width = bus_timing_0[7:6];
659
/* End Bus Timing 0 register */
660
 
661
 
662
/* Bus Timing 1 register */
663
wire   [7:0] bus_timing_1;
664
can_register #(8) BUS_TIMING_1_REG
665
( .data_in(data_in),
666
  .data_out(bus_timing_1),
667
  .we(we_bus_timing_1),
668
  .clk(clk)
669
);
670
 
671
assign time_segment1 = bus_timing_1[3:0];
672
assign time_segment2 = bus_timing_1[6:4];
673
assign triple_sampling = bus_timing_1[7];
674
/* End Bus Timing 1 register */
675
 
676
 
677
/* Error Warning Limit register */
678
can_register_asyn #(8, 96) ERROR_WARNING_REG
679
( .data_in(data_in),
680
  .data_out(error_warning_limit),
681
  .we(we_error_warning_limit),
682
  .clk(clk),
683
  .rst(rst)
684
);
685
/* End Error Warning Limit register */
686
 
687
 
688
 
689
/* Clock Divider register */
690
wire   [7:0] clock_divider;
691
wire         clock_off;
692
wire   [2:0] cd;
693
reg    [2:0] clkout_div;
694
reg    [2:0] clkout_cnt;
695
reg          clkout_tmp;
696
//reg          clkout;
697
 
698
can_register #(1) CLOCK_DIVIDER_REG_7
699
( .data_in(data_in[7]),
700
  .data_out(clock_divider[7]),
701
  .we(we_clock_divider_hi),
702
  .clk(clk)
703
);
704
 
705
assign clock_divider[6:4] = 3'h0;
706
 
707
can_register #(1) CLOCK_DIVIDER_REG_3
708
( .data_in(data_in[3]),
709
  .data_out(clock_divider[3]),
710
  .we(we_clock_divider_hi),
711
  .clk(clk)
712
);
713
 
714
can_register #(3) CLOCK_DIVIDER_REG_LOW
715
( .data_in(data_in[2:0]),
716
  .data_out(clock_divider[2:0]),
717
  .we(we_clock_divider_low),
718
  .clk(clk)
719
);
720
 
721
assign extended_mode = clock_divider[7];
722
assign clock_off     = clock_divider[3];
723
assign cd[2:0]       = clock_divider[2:0];
724
 
725
 
726
 
727
always @ (cd)
728
begin
729
  case (cd)                       // synopsys_full_case synopsys_paralel_case
730
    3'b000 : clkout_div <= 0;
731
    3'b001 : clkout_div <= 1;
732
    3'b010 : clkout_div <= 2;
733
    3'b011 : clkout_div <= 3;
734
    3'b100 : clkout_div <= 4;
735
    3'b101 : clkout_div <= 5;
736
    3'b110 : clkout_div <= 6;
737
    3'b111 : clkout_div <= 0;
738
  endcase
739
end
740
 
741
 
742
 
743
always @ (posedge clk or posedge rst)
744
begin
745
  if (rst)
746
    clkout_cnt <= 3'h0;
747
  else if (clkout_cnt == clkout_div)
748
    clkout_cnt <=#Tp 3'h0;
749
  else
750
    clkout_cnt <= clkout_cnt + 1'b1;
751
end
752
 
753
 
754
 
755
always @ (posedge clk or posedge rst)
756
begin
757
  if (rst)
758
    clkout_tmp <= 1'b0;
759
  else if (clkout_cnt == clkout_div)
760
    clkout_tmp <=#Tp ~clkout_tmp;
761
end
762
 
763
 
764
/*
765
//always @ (cd or clk or clkout_tmp or clock_off)
766
always @ (cd or clkout_tmp or clock_off)
767
begin
768
  if (clock_off)
769
    clkout <=#Tp 1'b1;
770
//  else if (&cd)
771
//    clkout <=#Tp clk;
772
  else
773
    clkout <=#Tp clkout_tmp;
774
end
775
*/
776
assign clkout = clock_off ? 1'b1 : ((&cd)? clk : clkout_tmp);
777
 
778
 
779
 
780
/* End Clock Divider register */
781
 
782
 
783
 
784
 
785
/* This section is for BASIC and EXTENDED mode */
786
 
787
/* Acceptance code register */
788
can_register #(8) ACCEPTANCE_CODE_REG0
789
( .data_in(data_in),
790
  .data_out(acceptance_code_0),
791
  .we(we_acceptance_code_0),
792
  .clk(clk)
793
);
794
/* End: Acceptance code register */
795
 
796
 
797
/* Acceptance mask register */
798
can_register #(8) ACCEPTANCE_MASK_REG0
799
( .data_in(data_in),
800
  .data_out(acceptance_mask_0),
801
  .we(we_acceptance_mask_0),
802
  .clk(clk)
803
);
804
/* End: Acceptance mask register */
805
/* End: This section is for BASIC and EXTENDED mode */
806
 
807
 
808
/* Tx data 0 register. */
809
can_register #(8) TX_DATA_REG0
810
( .data_in(data_in),
811
  .data_out(tx_data_0),
812
  .we(we_tx_data_0),
813
  .clk(clk)
814
);
815
/* End: Tx data 0 register. */
816
 
817
 
818
/* Tx data 1 register. */
819
can_register #(8) TX_DATA_REG1
820
( .data_in(data_in),
821
  .data_out(tx_data_1),
822
  .we(we_tx_data_1),
823
  .clk(clk)
824
);
825
/* End: Tx data 1 register. */
826
 
827
 
828
/* Tx data 2 register. */
829
can_register #(8) TX_DATA_REG2
830
( .data_in(data_in),
831
  .data_out(tx_data_2),
832
  .we(we_tx_data_2),
833
  .clk(clk)
834
);
835
/* End: Tx data 2 register. */
836
 
837
 
838
/* Tx data 3 register. */
839
can_register #(8) TX_DATA_REG3
840
( .data_in(data_in),
841
  .data_out(tx_data_3),
842
  .we(we_tx_data_3),
843
  .clk(clk)
844
);
845
/* End: Tx data 3 register. */
846
 
847
 
848
/* Tx data 4 register. */
849
can_register #(8) TX_DATA_REG4
850
( .data_in(data_in),
851
  .data_out(tx_data_4),
852
  .we(we_tx_data_4),
853
  .clk(clk)
854
);
855
/* End: Tx data 4 register. */
856
 
857
 
858
/* Tx data 5 register. */
859
can_register #(8) TX_DATA_REG5
860
( .data_in(data_in),
861
  .data_out(tx_data_5),
862
  .we(we_tx_data_5),
863
  .clk(clk)
864
);
865
/* End: Tx data 5 register. */
866
 
867
 
868
/* Tx data 6 register. */
869
can_register #(8) TX_DATA_REG6
870
( .data_in(data_in),
871
  .data_out(tx_data_6),
872
  .we(we_tx_data_6),
873
  .clk(clk)
874
);
875
/* End: Tx data 6 register. */
876
 
877
 
878
/* Tx data 7 register. */
879
can_register #(8) TX_DATA_REG7
880
( .data_in(data_in),
881
  .data_out(tx_data_7),
882
  .we(we_tx_data_7),
883
  .clk(clk)
884
);
885
/* End: Tx data 7 register. */
886
 
887
 
888
/* Tx data 8 register. */
889
can_register #(8) TX_DATA_REG8
890
( .data_in(data_in),
891
  .data_out(tx_data_8),
892
  .we(we_tx_data_8),
893
  .clk(clk)
894
);
895
/* End: Tx data 8 register. */
896
 
897
 
898
/* Tx data 9 register. */
899
can_register #(8) TX_DATA_REG9
900
( .data_in(data_in),
901
  .data_out(tx_data_9),
902
  .we(we_tx_data_9),
903
  .clk(clk)
904
);
905
/* End: Tx data 9 register. */
906
 
907
 
908
/* Tx data 10 register. */
909
can_register #(8) TX_DATA_REG10
910
( .data_in(data_in),
911
  .data_out(tx_data_10),
912
  .we(we_tx_data_10),
913
  .clk(clk)
914
);
915
/* End: Tx data 10 register. */
916
 
917
 
918
/* Tx data 11 register. */
919
can_register #(8) TX_DATA_REG11
920
( .data_in(data_in),
921
  .data_out(tx_data_11),
922
  .we(we_tx_data_11),
923
  .clk(clk)
924
);
925
/* End: Tx data 11 register. */
926
 
927
 
928
/* Tx data 12 register. */
929
can_register #(8) TX_DATA_REG12
930
( .data_in(data_in),
931
  .data_out(tx_data_12),
932
  .we(we_tx_data_12),
933
  .clk(clk)
934
);
935
/* End: Tx data 12 register. */
936
 
937
 
938
 
939
 
940
 
941
/* This section is for EXTENDED mode */
942
 
943
/* Acceptance code register 1 */
944
can_register #(8) ACCEPTANCE_CODE_REG1
945
( .data_in(data_in),
946
  .data_out(acceptance_code_1),
947
  .we(we_acceptance_code_1),
948
  .clk(clk)
949
);
950
/* End: Acceptance code register */
951
 
952
 
953
/* Acceptance code register 2 */
954
can_register #(8) ACCEPTANCE_CODE_REG2
955
( .data_in(data_in),
956
  .data_out(acceptance_code_2),
957
  .we(we_acceptance_code_2),
958
  .clk(clk)
959
);
960
/* End: Acceptance code register */
961
 
962
 
963
/* Acceptance code register 3 */
964
can_register #(8) ACCEPTANCE_CODE_REG3
965
( .data_in(data_in),
966
  .data_out(acceptance_code_3),
967
  .we(we_acceptance_code_3),
968
  .clk(clk)
969
);
970
/* End: Acceptance code register */
971
 
972
 
973
/* Acceptance mask register 1 */
974
can_register #(8) ACCEPTANCE_MASK_REG1
975
( .data_in(data_in),
976
  .data_out(acceptance_mask_1),
977
  .we(we_acceptance_mask_1),
978
  .clk(clk)
979
);
980
/* End: Acceptance code register */
981
 
982
 
983
/* Acceptance mask register 2 */
984
can_register #(8) ACCEPTANCE_MASK_REG2
985
( .data_in(data_in),
986
  .data_out(acceptance_mask_2),
987
  .we(we_acceptance_mask_2),
988
  .clk(clk)
989
);
990
/* End: Acceptance code register */
991
 
992
 
993
/* Acceptance mask register 3 */
994
can_register #(8) ACCEPTANCE_MASK_REG3
995
( .data_in(data_in),
996
  .data_out(acceptance_mask_3),
997
  .we(we_acceptance_mask_3),
998
  .clk(clk)
999
);
1000
/* End: Acceptance code register */
1001
 
1002
 
1003
/* End: This section is for EXTENDED mode */
1004
 
1005
 
1006
 
1007
 
1008
// Reading data from registers
1009
always @ ( addr or read or extended_mode or mode or bus_timing_0 or bus_timing_1 or clock_divider or
1010
           acceptance_code_0 or acceptance_code_1 or acceptance_code_2 or acceptance_code_3 or
1011
           acceptance_mask_0 or acceptance_mask_1 or acceptance_mask_2 or acceptance_mask_3 or
1012
           reset_mode or tx_data_0 or tx_data_1 or tx_data_2 or tx_data_3 or tx_data_4 or
1013
           tx_data_5 or tx_data_6 or tx_data_7 or tx_data_8 or tx_data_9 or status or
1014
           error_warning_limit or rx_err_cnt or tx_err_cnt or irq_en_ext or irq_reg or mode_ext or
1015
           arbitration_lost_capture or rx_message_counter or mode_basic or error_capture_code
1016
         )
1017
begin
1018
  if(read)  // read
1019
    begin
1020
      if (extended_mode)    // EXTENDED mode (Different register map depends on mode)
1021
        begin
1022
          case(addr)
1023 70 mohor
            8'd0  :  data_out <= {4'b0000, mode_ext[3:1], mode[0]};
1024
            8'd1  :  data_out <= 8'h0;
1025
            8'd2  :  data_out <= status;
1026
            8'd3  :  data_out <= irq_reg;
1027
            8'd4  :  data_out <= irq_en_ext;
1028
            8'd6  :  data_out <= bus_timing_0;
1029
            8'd7  :  data_out <= bus_timing_1;
1030
            8'd11 :  data_out <= {3'h0, arbitration_lost_capture[4:0]};
1031
            8'd12 :  data_out <= error_capture_code;
1032
            8'd13 :  data_out <= error_warning_limit;
1033
            8'd14 :  data_out <= rx_err_cnt;
1034
            8'd15 :  data_out <= tx_err_cnt;
1035
            8'd16 :  data_out <= acceptance_code_0;
1036
            8'd17 :  data_out <= acceptance_code_1;
1037
            8'd18 :  data_out <= acceptance_code_2;
1038
            8'd19 :  data_out <= acceptance_code_3;
1039
            8'd20 :  data_out <= acceptance_mask_0;
1040
            8'd21 :  data_out <= acceptance_mask_1;
1041
            8'd22 :  data_out <= acceptance_mask_2;
1042
            8'd23 :  data_out <= acceptance_mask_3;
1043
            8'd24 :  data_out <= 8'h0;
1044
            8'd25 :  data_out <= 8'h0;
1045
            8'd26 :  data_out <= 8'h0;
1046
            8'd27 :  data_out <= 8'h0;
1047
            8'd28 :  data_out <= 8'h0;
1048
            8'd29 :  data_out <= {1'b0, rx_message_counter};
1049
            8'd31 :  data_out <= clock_divider;
1050 66 mohor
 
1051 70 mohor
            default: data_out <= 8'h0;
1052 66 mohor
          endcase
1053
        end
1054
      else                  // BASIC mode
1055
        begin
1056
          case(addr)
1057 70 mohor
            8'd0  :  data_out <= {3'b001, mode_basic[4:1], mode[0]};
1058
            8'd1  :  data_out <= 8'hff;
1059
            8'd2  :  data_out <= status;
1060
            8'd3  :  data_out <= {4'hf, irq_reg[3:0]};
1061
            8'd4  :  data_out <= reset_mode? acceptance_code_0 : 8'hff;
1062
            8'd5  :  data_out <= reset_mode? acceptance_mask_0 : 8'hff;
1063
            8'd6  :  data_out <= reset_mode? bus_timing_0 : 8'hff;
1064
            8'd7  :  data_out <= reset_mode? bus_timing_1 : 8'hff;
1065
            8'd10 :  data_out <= reset_mode? 8'hff : tx_data_0;
1066
            8'd11 :  data_out <= reset_mode? 8'hff : tx_data_1;
1067
            8'd12 :  data_out <= reset_mode? 8'hff : tx_data_2;
1068
            8'd13 :  data_out <= reset_mode? 8'hff : tx_data_3;
1069
            8'd14 :  data_out <= reset_mode? 8'hff : tx_data_4;
1070
            8'd15 :  data_out <= reset_mode? 8'hff : tx_data_5;
1071
            8'd16 :  data_out <= reset_mode? 8'hff : tx_data_6;
1072
            8'd17 :  data_out <= reset_mode? 8'hff : tx_data_7;
1073
            8'd18 :  data_out <= reset_mode? 8'hff : tx_data_8;
1074
            8'd19 :  data_out <= reset_mode? 8'hff : tx_data_9;
1075
            8'd31 :  data_out <= clock_divider;
1076 66 mohor
 
1077 70 mohor
            default: data_out <= 8'h0;
1078 66 mohor
          endcase
1079
        end
1080
    end
1081
  else
1082 70 mohor
    data_out <= 8'h0;
1083 66 mohor
end
1084
 
1085
 
1086
// Some interrupts exist in basic mode and in extended mode. Since they are in different registers they need to be multiplexed.
1087
assign data_overrun_irq_en  = extended_mode ? data_overrun_irq_en_ext  : overrun_irq_en_basic;
1088
assign error_warning_irq_en = extended_mode ? error_warning_irq_en_ext : error_irq_en_basic;
1089
assign transmit_irq_en      = extended_mode ? transmit_irq_en_ext      : transmit_irq_en_basic;
1090
assign receive_irq_en       = extended_mode ? receive_irq_en_ext       : receive_irq_en_basic;
1091
 
1092
 
1093
reg data_overrun_irq;
1094
always @ (posedge clk or posedge rst)
1095
begin
1096
  if (rst)
1097
    data_overrun_irq <= 1'b0;
1098
  else if (overrun & (~overrun_q) & data_overrun_irq_en)
1099
    data_overrun_irq <=#Tp 1'b1;
1100
  else if (read_irq_reg)
1101
    data_overrun_irq <=#Tp 1'b0;
1102
end
1103
 
1104
 
1105
reg transmit_irq;
1106
always @ (posedge clk or posedge rst)
1107
begin
1108
  if (rst)
1109
    transmit_irq <= 1'b0;
1110
  else if (transmit_buffer_status & (~transmit_buffer_status_q) & transmit_irq_en)
1111
    transmit_irq <=#Tp 1'b1;
1112
  else if (read_irq_reg)
1113
    transmit_irq <=#Tp 1'b0;
1114
end
1115
 
1116
 
1117
reg receive_irq;
1118
always @ (posedge clk or posedge rst)
1119
begin
1120
  if (rst)
1121
    receive_irq <= 1'b0;
1122
  else if (release_buffer)
1123
    receive_irq <=#Tp 1'b0;
1124
  else if ((~info_empty) & (~receive_irq) & receive_irq_en)
1125
    receive_irq <=#Tp 1'b1;
1126
end
1127
 
1128
 
1129
reg error_irq;
1130
always @ (posedge clk or posedge rst)
1131
begin
1132
  if (rst)
1133
    error_irq <= 1'b0;
1134
  else if (((error_status ^ error_status_q) | (node_bus_off ^ node_bus_off_q)) & error_warning_irq_en)
1135
    error_irq <=#Tp 1'b1;
1136
  else if (read_irq_reg)
1137
    error_irq <=#Tp 1'b0;
1138
end
1139
 
1140
 
1141
reg bus_error_irq;
1142
always @ (posedge clk or posedge rst)
1143
begin
1144
  if (rst)
1145
    bus_error_irq <= 1'b0;
1146
  else if (set_bus_error_irq & bus_error_irq_en)
1147
    bus_error_irq <=#Tp 1'b1;
1148
  else if (read_irq_reg)
1149
    bus_error_irq <=#Tp 1'b0;
1150
end
1151
 
1152
 
1153
reg arbitration_lost_irq;
1154
always @ (posedge clk or posedge rst)
1155
begin
1156
  if (rst)
1157
    arbitration_lost_irq <= 1'b0;
1158
  else if (set_arbitration_lost_irq & arbitration_lost_irq_en)
1159
    arbitration_lost_irq <=#Tp 1'b1;
1160
  else if (read_irq_reg)
1161
    arbitration_lost_irq <=#Tp 1'b0;
1162
end
1163
 
1164
 
1165
 
1166
reg error_passive_irq;
1167
always @ (posedge clk or posedge rst)
1168
begin
1169
  if (rst)
1170
    error_passive_irq <= 1'b0;
1171
  else if ((node_error_passive & (~node_error_passive_q) | (~node_error_passive) & node_error_passive_q & node_error_active) & error_passive_irq_en)
1172
    error_passive_irq <=#Tp 1'b1;
1173
  else if (read_irq_reg)
1174
    error_passive_irq <=#Tp 1'b0;
1175
end
1176
 
1177
 
1178
 
1179
assign irq_reg = {bus_error_irq, arbitration_lost_irq, error_passive_irq, 1'b0, data_overrun_irq, error_irq, transmit_irq, receive_irq};
1180
 
1181
assign irq = data_overrun_irq | transmit_irq | receive_irq | error_irq | bus_error_irq | arbitration_lost_irq | error_passive_irq;
1182
 
1183
 
1184
 
1185
 
1186
 
1187
endmodule

powered by: WebSVN 2.1.0

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