English
Language : 

SH7047F Datasheet, PDF (71/85 Pages) Renesas Technology Corp – Renesas 32-Bit RISC Microcomputer SuperH RISC engine Family/SH7047 Series
5.5 Transmission Program Listing
/********************************************************************************/
/*
HCAN-2 Transmission Program (Example 5)
*/
/********************************************************************************/
#include <stdio.h>
/* Library function header file */
#include <machine.h>
/* Library function header file */
#include "SH7047.h"
/* Peripheral register definition header file */
/********************************************************************************/
/*
Function prototype declarations
*/
/********************************************************************************/
void t_main(void );
void RM1_IRR1(void);
void DTC_SWDTEND(void);
/********************************************************************************/
/*
Define constants
*/
/********************************************************************************/
#define DTMR (*(unsigned short *)0xFFFFD080) /* DTC register data */
#define DTCRA (*(unsigned short *)0xFFFFD082) /* DTC register data */
#define DTCRB (*(unsigned short *)0xFFFFD086) /* DTC register data */
#define DTSAR (*(unsigned long *)0xFFFFD088) /* DTC register data */
#define DTDAR (*(unsigned long *)0xFFFFD08C) /* DTC register data */
#define MBbuff (*(unsigned char *)0xFFFFD100) /* Storage area for received data */
/********************************************************************************/
/*
Main routine
*/
/********************************************************************************/
void t_main(void){
unsigned short *work;
/* Initialize storage area for received data */
work = (unsigned short *)0xFFFFD100;
do {
*work = 0x0000;
work++;
} while(work < (unsigned short *)0xFFFFD108);
/* Clear bit MCR0 */
HCAN_MCR = 0x0000;
/* Clear reset request bit */
/* Set local acceptance filter */
HCAN_MB1.LAFM15 = 0x0000;
/* Set identifier filter mask for mailbox 1 */
/* Clear bit IRR0 */
HCAN_IRR = 0x0001;
/* Clear reset interrupt flag (to clear, write 1) */
/* Set pins */
PB.PBCR1 = 0x0000;
/* Set PB HCAN-2 */
PB.PBCR2 = 0x000F;
/* Set PB HCAN-2 */
/* Set bit rate (BCR): bit rate is 250 kbps when φ = 50 MHz */
HCAN_BCR0 = 0x0009;
/* BRP=9(10 system clock) */
HCAN_BCR1 = 0x4300;
/* TSEG1=4(5tq),TSEG2=3(4tq) */
/* Initialize mailbox */
work = (unsigned short *)0xFFFFB100;
do {
Rev. 1.00, 08/03, page 63 of 74