CC770

Download as pdf or txt
Download as pdf or txt
You are on page 1of 85
At a glance
Powered by AI
The document provides technical specifications and details about a CAN controller chip called CC770 from Bosch. It describes features, functions, parameters, diagrams and revisions of the chip.

The document is a data sheet that provides technical specifications and details about a CAN controller chip called CC770 from Bosch. It describes features, functions, parameters, diagrams, ordering information and revisions of the chip.

The document went through several revisions - 1.0 was the initial version, 1.1-1.8 added more details, corrected errors and documented changes between revisions. Key changes included adding more details to diagrams, parameters, erratum fixes and additions.

CC770

Data Sheet

Rev. 1.8

CC770
(Stand Alone CAN Controller) Data Sheet
Revision 1.8
14.09.2010

Robert Bosch GmbH Automotive Electronics

- 1/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Disclaimer

1)

The products of the division Automotive Electronics of Robert Bosch GmbH (hereinafter "Bosch AE Components") are developed for use in automotive systems. They may only be used within the parameters of this product data sheet. The information in this data sheet is only given to describe certain components and their functions and shall not be considered as warranted characteristics. Any liability for infringement of intellectual property rights due to applying the information for the data sheet shall be excluded. The examination of tness for the intended use is the sole responsibility of the customer. The resale and/or use of Bosch AE Components are at the customers own risk and at his own responsibility. All operating parameters must be validated by the customer for each customer application by technical experts of the customer. Unless otherwise expressly agreed in writing and without limitation Bosch AE Components are not designed, intended, or authorized for use as components in systems intended to support or sustain life. In the event of any use of Bosch AE Components outside the Bosch expressly approved applications, specied environments, installation conditions or in the event of any unintended use or misuse, Customer shall indemnify and hold Bosch harmless against all claims, costs, incidental or consequential damages, and expenses arising out of such use, directly or indirectly. The Customer must monitor the market for the purchased Bosch AE Components, particularly with respect to product safety and inform Bosch AE without delay of all security relevant incidents. Unless otherwise expressly agreed in writing Bosch reserves the right, at any time, to change the data sheet.

2)

3)

4)

5)

6)

- 2/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Ordering information
Device Name Packages Product Number : : : CC770 LQFP 44, PLCC44 CC770F LQFP44 package(lead-free) : 0 272 240 159 CC770F PLCC44 package(lead-free) : 0 272 240 160 CC770E LQFP44 package(lead-free) : 0 272 240 007 CC770E PLCC44 package(lead-free) : 0 272 240 123 CC770E PLCC44 package : 0 272 230 535

- 3/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.1 Feature list . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 1.2 Feature description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 1.3 Functional Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 1.4 CC770 Block Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 1.4.1 CAN Controller . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 1.4.2 Intelligent Memory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 1.4.3 CPU Interface Logic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 1.4.4 Clockout . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 1.4.5 Two 8-Bit Ports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11

2. Package Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 3. Product Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13


3.1 Pin Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 3.2 Hardware Reset . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 3.2.1 Reset values of CC770 registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 3.2.2 Reset values of CC770 output pins . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 3.3 Software Initialization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 3.4 Configuration of Bit Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 3.5 Silent Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 3.6 Low Current Modes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18

4. Functional Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
4.1 CC770 Address Map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 4.2 Control Register (00H) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 4.3 Status Register (01H) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 4.3.1 Status Interrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 4.4 CPU Interface Register (02H) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 4.4.1 Clocking Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 4.5 High Speed Read Register (04+05H) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 4.5.1 Double Read Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 4.6 Global Mask - Standard Register (06-07H) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 4.7 Global Mask - Extended Register (08-0BH) . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 4.8 Acceptance Filtering Implications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 4.9 Message 15 Mask Register (0C-0FH) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 4.10 ClkOut Register (1FH) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 4.11 Bus Configuration Register (2FH) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 4.12 Receive Error Counter (6FH) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 - 4/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

4.13 Transmit Error Counter (7FH) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 4.14 Bit Timing Registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 4.14.1 Bit Timing Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 4.14.2 CC770 Bit Timing Definitions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 4.14.3 CC770 Bit Time Segments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 4.14.4 Calculation of the Bit Time . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 4.14.5 Example for Bit Timing at high Baudrate . . . . . . . . . . . . . . . . . . . . . . . . . 40 4.14.6 Bit Timing Registers 0 + 1 (3FH + 4FH) . . . . . . . . . . . . . . . . . . . . . . . . . . 40 4.15 Interrupt Register (5FH) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 4.16 Serial Reset Address (FFH) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 4.17 CC770 Message Objects (MO) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 4.17.1 Message Object Structure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 4.17.2 Control 0 + 1 Registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 4.17.3 Handling of Message Objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 4.17.4 Arbitration 0, 1, 2, 3 Registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 4.17.5 Configuration Register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 4.17.6 Data Bytes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 4.18 Special Treatment of Message Object 15 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52

5. Port Registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
5.1 Port 1 Registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 5.2 Port 2 Registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54

6. FLOW DIAGRAMS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
6.1 CC770 handling of Message Objects 1-14 (Transmit) . . . . . . . . . . . . . . . . . . . . 55 6.2 CC770 handling of Message Objects 1-14 (Receive) . . . . . . . . . . . . . . . . . . . . . 56 6.3 CPU Handling of Message Objects 1-14 (Transmit) . . . . . . . . . . . . . . . . . . . . . 57 6.4 CPU Handling of Message Objects 1-14 (Receive) . . . . . . . . . . . . . . . . . . . . . . 58 6.5 CPU Handling of Message Object 15 (Receive) . . . . . . . . . . . . . . . . . . . . . . . . 59

7. CPU Interface Logic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60


7.1 CPU Interface Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 7.2 Parallel Interfacing Techniques . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 7.3 Serial Interface Techniques . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 7.4 Serial Interface Protocol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 7.5 Serial Control Byte . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63

8. Electrical Specification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
8.1 Handling Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 8.2 Absolute Maximum Ratings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 - 5/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

8.3 D.C. Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 8.4 A.C. Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 8.4.1 A.C. Characteristics for start-up . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 8.4.2 A.C. Characteristics for clocks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 8.4.3 A.C. Characteristics for CAN interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 8.4.4 A.C. Characteristics for 8/16-Bit Multiplexed Modes (Modes 0, 1) . . . . . . 68 8.4.5 A.C. Characteristics for 8-Bit Multiplexed Mode 2 . . . . . . . . . . . . . . . . . . . 71 8.4.6 A.C. Characteristics for 8-Bit Non-Multiplexed Asynchronous (Mode 3) . . 73 8.4.7 A.C. Characteristics for 8-Bit Non-Multiplexed Synchronous (Mode 3) . . . 76 8.4.8 A.C. Characteristics for Serial Interface Mode . . . . . . . . . . . . . . . . . . . . . . 78 8.4.9 Waveforms for testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80

9. Errata . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
9.1 Interrupt update during Initialization Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81 9.1.1 Scope . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81 9.1.2 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81 9.1.3 Work-around . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81

10. Appendix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
10.1 Documentation of Changes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 10.1.1 Changes on Revisions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 10.1.1.1 Revision 1.0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 10.1.1.2 Revision 1.1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 10.1.1.3 Revision 1.2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 10.1.1.4 Revision 1.3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 10.1.1.5 Revision 1.4 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 10.1.1.6 Revision 1.5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 10.1.1.7 Revision 1.6 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 10.1.1.8 Revision 1.7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 10.1.1.9 Revision 1.8 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85

- 6/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

1. Introduction
1.1 Feature list
Supports CAN Protocol Version 2.0 A, B Standard Data and Remote Frames Extended Data and Remote Frames Programmable Global Mask Standard Message Identier Extended Message Identier 15 Message Objects of 8-byte Data Length 14 Tx/Rx Buffers 1 Rx Buffer with Shadow Buffer and Programmable Mask Programmable Bit Rate Flexible CPU Interface 8-bit Multiplexed 16-bit Multiplexed 8-bit Synchronous Non-Multiplexed 8-bit Asynchronous Non-Multiplexed Serial Interface Two 8-bit Bidirectional l/O Ports Flexible Interrupt Structure Flexible Status Interface Programmable Clock Output LQFP44 and PLCC44 Package, Chip

1.2 Feature description


The CC770 is a highly integrated serial communications controller that performs serial communication according to the CAN Protocol Version 2.0 A, B. The CAN protocol uses a multimaster (contention based) bus conguration for the transfer of communication objects between nodes of the network. This multi-master bus is also referred to as CSMA/CR or Carrier Sense, Multiple Access, with Collision Resolution. The CC770 performs all serial communication functions such as transmission and reception of messages, message ltering, transmit search, and interrupt search with minimal interaction from the host microcontroller, or CPU. The CC770 supports the standard and extended message frames in CAN Specication 2.0 part B. It has the capability to transmit, receive, and perform message ltering on extended message frames with a 29-bit message identier. Due to the backward compatible nature of CAN Specication 2.0, the CC770 also fully supports the standard message frames in CAN Specication 2.0 part A. A communication object consists of an identier along with control data segments. The con- 7/85 14.09.2010 BOSCH Common_Introduction.fm Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

trol segment contains all the information needed to transfer the message. The data segment contains from 0 to 8 bytes in a single message. All communication objects are stored in the Memory of the corresponding CAN chip for each node. A transmitting node broadcasts its message to all other nodes on the network. An acceptance lter at each node decides whether to receive that message. A message is accepted only if a communication object with a matching message identier has been set up in the CAN Memory for that node. CAN not only manages the transmission and reception of messages but also the error handling, without any burden on the CPU. CAN features several error detection mechanisms. These include Cyclical Redundancy Check (CRC) and bit coding rules (bit stufng/destufng). The polynomial of the CRC has been optimized for control applications with short messages. If a message was corrupted by noise during transmission, it is not accepted at the receiving nodes. Current transmission status is monitored in the control segment of the appropriate communication object within the transmitting node, automatically initiating a repeated transmission in the case of lost arbitration or errors. CAN also has built-in mechanisms to locate error sources and to distinguish permanent hardware failures from occasional soft errors. Defective nodes are switched off the bus, implementing a fail-safe behaviour (thus, hardware errors will not let defective nodes control the bus indenitely). The message storage is implemented in an intelligent memory, which can be addressed by the CAN controller and the CPU. The CPU controls the CAN controller by selectively modifying the various registers and bit elds in the Memory. The content of the various bit elds are used to perform the functions of acceptance ltering, transmit search, interrupt search and transfer completion. In order to initiate a transfer, the transmission request bit has to be written to the message object. The entire transmission procedure and eventual error handling is then done without any CPU involvement. If a communication object has been congured to receive messages, the CPU easily reads its data registers using CPU read instructions. The message object may be congured to interrupt the CPU after every successful message transmission or reception. The CC770 features a powerful CPU interface that offers exibility to directly interface to many different CPUs. It can be congured to interface with CPUs using an 8-bit multiplexed, 16-bit multiplexed, or 8-bit non-multiplexed address/data bus for different architectures. A exible serial interface is also available when a parallel CPU interface is not required. The CC770 provides storage for 15 message objects of 8-byte data length. Each message object can be congured as either transmit or receive, except for the last message object. The last message object is a receive only double buffer with a dedicated acceptance mask designed to allow select groups of different message identiers to be received. The CC770 also implements a global acceptance masking feature for message ltering. This feature allows the user to globally mask any identier bits of the incoming message. There are different programmable global mask registers for standard and extended messages. The CC770 provides an improved set of network management and diagnostic functions including fault connement and a built-in monitoring tool. The built-in monitoring tool alerts the CPU when a global status change occurs. Global status changes include message transmission and reception, error frames, or sleep mode wake-up. In addition, each message object offers full exibility in detecting when a data or remote frame has been sent or - 8/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 received.

Data Sheet

Rev. 1.8

1.3 Functional Overview


The CC770 CAN controller consists of six functional blocks. The CPU Interface logic manages the interface between the CPU (host microcontroller) and the CC770 using an address/data bus or the SPI. The CAN controller interfaces to the CAN bus and implements the protocol rules of the CAN protocol for the transmission and reception of messages. The RAM is the interface layer between the CPU and the CAN bus. The two port blocks provide 8-bit low speed I/O capability. The clockout block allows the CC770 to drive other chips, such as the host-CPU. The CC770 RAM provides storage for 15 message objects of 8-byte data length. Each message object has a unique identier and can be congured to either transmit or receive, except for the last message object. The last message object is a receive only buffer with a special mask design to allow select groups of different message identiers to be received. Each message object contains control and status bits. A message object with the direction set as receive will send a remote frame by requesting a message transmission. A message object with the direction set as transmit will be congured to automatically send a data frame whenever a remote frame with a matching identier is received over the CAN bus. All message objects have separate transmit and receive interrupts and status bits, allowing the CPU full exibility in detecting when a remote or data frame has been sent or received. The CC770 also implements a global masking feature for acceptance ltering. This feature allows the user to globally mask, or dont care, any identier bits of the incoming message. This mask is programmable to allow the user to design an application-specic message identication strategy. There are separate global masks for standard and extended frames. The incoming message rst passes through the global mask and is matched to the identiers in message objects 1-14. If there is no identier match then the message passes through the local mask in message object 15. The local mask allows a large number of infrequent messages to be received by the CC770. Message object 15 is also buffered to allow the CPU time to service a message received.

- 9/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

1.4 CC770 Block Diagram


The CC770 consists of the following functional blocks:

PORT1 PORT2

PORT1 PORT2 INTELLIGENT MEMORY ADDRESS/ DATA BUS CONTROL BUS SPI CAN CONTROLLER RX0 RX1 TX0 TX1

CPU INTERFACE LOGIC


CLKOUT

MODE0

MODE1

CLKOUT

Figure 1: Block Diagram of CC770.

1.4.1 CAN Controller The CAN controller controls the data stream between the Memory (parallel data) and the CAN busline (serial data). The CAN controller also handles the error management logic and the message objects. 1.4.2 Intelligent Memory The Memory is content addressable (CAM) for the CAN Controller which does the acceptance ltering in one clock cycle, whereas the CPU Interface Logic accesses the Memory via register address (RAM). The advantage of this access is the speed and the minimized area. The access to the CAM is timeshared between the CPU Interface Logic and the CAN bus (through the CAN controller). The Memory is addressed from 00H to FFH.

- 10/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 1.4.3 CPU Interface Logic

Data Sheet

Rev. 1.8

The CC770 provides a exible CPU interface capable of interfacing to many commonly used microcontrollers. The following ve modes could be selected using two CPU interface MODE0 and MODE1 pins and the RD# and WR# pins: Mode 0 (1) is an 8-bit multiplexed address data bus using RD# and WR# pins. If the RD# and WR# pins are tied low at reset in Mode 0, the serial interface (SPI) mode is entered. Mode 1 (2) selects 16-bit multiplexed address data bus. Mode 2 (3) selects an 8-bit multiplexed address data bus using E and R/W# pins. Mode 3 (4) selects an 8-bit non-multiplexed address data bus for either synchronous or asynchronous communication. 1.4.4 Clockout The on-chip clock generator consists of an oscillator, clock divider register and a driver circuit. The Clockout output range is XTAL (external crystal frequency) to XTAL/15. The Clockout output driving strength (slew rate) is programmable in four steps. 1.4.5 Two 8-Bit Ports Two 8-bit low speed input/output (I/O) ports are available on-chip. Depending on the CPU interface selected, at least 7 and up to 16 of these I/O pins are available for system use.

1. MODE1 pin = 0, MODE0 pin = 0 2. MODE1 pin = 0, MODE0 pin = 1 3. MODE1 pin = 1, MODE0 pin = 0 4. MODE1 pin = 1, MODE0 pin = 1

- 11/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

2. Package Diagram

(Package: LQFP44)
P1.2/AD10 P1.3/AD11 P1.4/AD12 P1.5/AD13 P1.6/AD14 P1.7/AD15 P1.0/AD8 P1.1/AD9 RESET# MODE1

AD6/SPICLK AD5 AD4/MOSI AD3 MODE0 VCC AD2 AD1 AD0 ALE/AS RD#/E

Date Code

Lot No.

(WR#/WRL#)/

P2.7/WRH#

P2.4

P2.3

P2.2

DSACK0#

P2.6/INT#

P2.5

P2.1

CS#

(R/W#)

(Package: PLCC44)
P1.2/AD10 P1.3/AD11 P1.4/AD12 P1.5/AD13 P1.6/AD14 P1.7/AD15 P1.0/AD8 P1.1/AD9 RESET# MODE1

39

AD7

38

37

36

35

34

33

32

31

P2.0

1 2 3 4 5 6 7 8 9 10 11

34 35 36 37 38 39 40 41 42 43 44

33 32 31 30 29 28 27 26 25 24 23

AD7

22 21 20 19 18 17 16 15 14 13 12

READY/MISO CLKOUT TX0 TX1 INT# VSS1 RX0 RX1 VSS2 XTAL2 XTAL1

Product Number (last 5 digits) Assembly Lot

30

29 28 27 26 25 24 23 22 21 20 19 18

AD6/SPICLK AD5 AD4/MOSI AD3 MODE0 VCC

40 41 42 43 44 1 2 3 4 5 6 10 11 12 13 14 15 16
(WR#/WRL#)/ (R/W#)

READY/MISO CLKOUT TX0 TX1 INT# VSS1 RX0 RX1 VSS2 XTAL2 XTAL1

Strip Mark
AD2 AD1 AD0 ALE/AS RD#/E

Product Number (last 5 digits) Date Code

Wafer Lot No.

P2.7/WRH#

P2.4

P2.3

P2.2

P2.6/INT#

P2.5

P2.1

CS#

Figure 2: Package Diagrams of CC770

- 12/85 14.09.2010 BOSCH Common_PackageDiagram.fm Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

DSACK0#

P2.0

17

CC770

Data Sheet

Rev. 1.8

3. Product Description
3.1 Pin Description
Symbol WR#/ WRL#/ R/W# CS# DSACK0# P2.7/ WRH# P2.6/ INT# P2.5 P2.4 P2.3 P2.2 P2.1 P2.0 XTAL1 XTAL2 LQFP PLCC pin pin 1 7 Function For CPU Interface Modes 0 and 1. For Mode 1, 16-bit multiplexed mode, function is: write low byte For CPU Interface Mode 2 and 3. A low level on this pin enables the CPU to access the CC770. DSACK0# is an open-drain output(1) to sychronize accesses from the CPU to the CC770 for CPU Interface Mode 3. Port 2, Bit 7(2) For Mode 1, 16-bit multiplexed mode, function is: write high byte Port 2, Bit 6(2) Interrupt output (INT#) when MUX bit = 1 in CPU Interface Register Port 2, Bit 5(2) Port 2, Bit 4(2) Port 2, Bit 3(2) Port 2, Bit 2(2) Port 2, Bit 1(2) Port 2, Bit 0(2) Input for an external clock. Push-pull output from the internal oscillator. XTAL2 and XTAL1 are the crystal connections to an internal oscillator. If an external oscillator is used, XTAL2 may not be connected. XTAL2 may not be used as a clock output to drive other CPUs. Ground (0V) connection must be shorted externally to a VSS board plane to provide analog ground for PLL. Inverting input from CAN bus transceiver if DcR0 bit in the Bus Conguration Register (Address 2FH) is set. Input from CAN bus transceiver if DcR0 bit in the Bus Conguration Register (Address 2FH) is zero. Ground (0V) connection must be shorted externally to a VSS board plane to provide digital ground. The interrupt pin is an open drain output (requires external pull up resistor) to the CPU. The function of this pin is determined by the MUX bit in the CPU Interface Register (Address 02H), see chapter 4.4. Inverted serial push-pull data output to the CAN bus transceiver. During a recessive bit TX1 is low, during a dominant bit TX1 is high.

2 3 4 5 6 7 8 9 10 11 12 13

8 9 10 11 12 13 14 15 16 17 18 19

VSS2 RX1 RX0 VSS1 INT#

14 15 16 17 18

20 21 22 23 24

TX1

19

25

Table 1: Pin description

- 13/85 14.09.2010 BOSCH Common_PinDescription.fm Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770
LQFP PLCC pin pin 20 21 22 26 27 28

Data Sheet

Rev. 1.8

Symbol TX0 CLKOUT READY/ MISO RESET# MODE1 P1.7-0 AD7-3 MODE0 VCC AD2-0 ALE/ AS RD#/ E

Function Serial push-pull data output to the CAN bus transceiver. During a recessive bit TX0 is high, during a dominant bit TX0 is low. Programmable clock output. This push-pull output may be used to drive the clock input of the CPU. READY is an open-drain output to synchronize accesses from the CPU to the CC770 for CPU Interface Modes 0 and 1. MISO is the serial push-pull data output in the SPI mode. Reset pin for CC770 initialisation. Timing requirements described in chapter 8.4.1. Select, together with Pin 44, one of the four parallel interface modes.(3)

23 24

29 30

25-32 31-38 Port 1 with multi Function Pins, see Table 2.(2) 33-37 39-43 Multi Function Pins, see Table 2. 38 39 44 1 Select, together with Pin 30, one of the four parallel interface modes. See chapter 7.1.(3) Power connection must be shorted externally to +5V DC to provide power to the entire chip.

40-42 2 - 4 Multi Function Pin, see Table 2. 43 44 5 6 ALE used for CPU Interface Modes 0 and 1. AS used for Mode 2. (In Mode 3, pin must be tied high.) RD# used for CPU Interface Modes 0 and 1. E used for Mode 2. (In Mode 3 Asynchronous, pin must be tied high.)

Table 1: Pin description

- 14/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Symbol

LQFP PLCC pin pin 42 41 40 37 36 35 34 33 32 31 30 29 28 27 26 25 4 3 2 43 42 41 40 39 38 37 36 35 34 33 32 31

Mode 0
8-Bit Multiplexed (RD# & WR#)

Mode 1
16-Bit Multiplexed

Mode 2
8-Bit Multiplexed (E & R/W#)

Mode 3
8-Bit NonMultiplexed

SPI-Mode
Serial Interface

AD0 AD1 AD2 AD3 AD4/MOSI AD5 AD6/SPICLK AD7 P1.0/AD8 P1.1/AD9 P1.2/AD10 P1.3/AD11 P1.4/AD12 P1.5/AD13 P1.6/AD14 P1.7/AD15

AD0 AD1 AD2 AD3 AD4 AD5 AD6 AD7 P1.0 P1.1 P1.2 P1.3 P1.4 P1.5 P1.6 P1.7

AD0 AD1 AD2 AD3 AD4 AD5 AD6 AD7 AD8 AD9 AD10 AD11 AD12 AD13 AD14 AD15

AD0 AD1 AD2 AD3 AD4 AD5 AD6 AD7 P1.0 P1.1 P1.2 P1.3 P1.4 P1.5 P1.6 P1.7

A0 A1 A2 A3 A4 A5 A6 A7 D0 D1 D2 D3 D4 D5 D6 D7

ICP CP CSAS STE MOSI Unused SPICLK Unused P1.0 P1.1 P1.2 P1.3 P1.4 P1.5 P1.6 P1.7

Table 2: Multi Function Pins

Notes to pin descriptions: (1) DSACK0# is often used as a pulldown output with a 3.3 k pullup resistor and a 100 pF load capacitance. An open-drain output is used because several peripherals may be connected to the DSACK0# line. The CC770 species a TCHKH timing (CS# high to DSACK0# high) equal to 55 ns, however a 3.3 k resistor will not sufciently charge the line when DSACK0# is oated by the CC770. To meet this timing, the CC770 has an active pullup that drives the DSACK0# output until it is high, and then the pullup is turned off. Therefore, the pullup is active for a short time only. Since the DSACK is also an input (to observe logic pin level for active pullup) this pin must be connected to an external pullup resistor in any case to avoid oscillation. If DSACK is not needed by application, the pullup resistor could have a higher impedance than 3.3 k (e.g. 100 k) to reduce current peaks. (2) Port1 and Port2 pins are weakly held high until the Port Conguration Registers have been written (locations 9FH and AFH respectively). (3) MODE0 and MODE1 pins are internally connected to weak pulldowns. These pins will - 15/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

be pulled low during reset if unconnected. Following reset, these pins oat.

3.2 Hardware Reset


3.2.1 Reset values of CC770 registers The registers of the CC770 have the following values after reset: Register Control Register Status Register CPU Interface Register High Speed Register Global Mask - Standard Global Mask - Extended Message 15 Mask Clockout Register Bus Conguration Bit Timing Register 0 Bit Timing Register 1 Interrupt Register P1 Conguration Register P2 Conguration Register P1 In P2 In PI Out P2 Out SPI Reset Address Message Objects 1-15
Table 3: Reset values of CC770 registers

Address 00H 01H 02H 04+05H 06+07H 08-0BH 0C-0FH 1FH 2FH 3FH 4FH 5FH 9FH AFH BFH CFH DFH EFH FFH

Reset Value 01H undened 61H unchanged unchanged unchanged unchanged 00H or 01H depending on CPU Interface Mode 00H 00H 00H 00H 00H 00H FFH FFH 00H 00H not readable unchanged

Notes: The error management counters and the Bus Off state are reset by a hardware reset. If a hardware reset occurs at power on, registers dened as unchanged should be interpreted as undened. Also regard timing requirements of reset pin described in chapter 8.4.1.

- 16/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

3.2.2 Reset values of CC770 output pins The behaviour of CC770 output pins in reset procedure: Pin MODE0/MODE1 Port 1/2 CLOCKOUT TX0 TX1 INT# DSACK0#
Table 4: Reset states of CC770 output pins

output state while reset is active weakly pulled low

output state direct after reset high impedance

weakly pulled high active 1 (recessive) 0 (recessive) oat oat

3.3 Software Initialization


Software initialization is started by setting the Init bit in the Control Register, either by software, hardware reset, or by going Bus Off. While Init is set, all message transfers to and from the CC770 are stopped and the TX0 and TX1 outputs are recessive. The error counters are unchanged. Initialization is used to congure the CC770 memory without interference to or by CAN bus. Resetting Init bit completes initialization and the CC770 synchronizes itself to the CAN bus by waiting for 11 consecutive recessive bits (called bus idle) before it will take part in bus activities. Note: The Bus Off recovery sequence (see CAN Specication Rev. 2.0) cannot be shortened by setting or resetting Init. If the device goes Bus Off, it will set Init of its own accord, stopping all bus activities. Once Init has been cleared by the CPU, the device will then wait for 129 occurrences of Bus Idle (129 * 11 consecutive recessive bits) before resuming normal operations. At the end of the Bus Off recovery sequence, the Error Management Counters will be reset. During the waiting time after the resetting of Init, each time a sequence of 11 recessive bits has been monitored, a Bit0Error code is written to the Status Register, enabling the CPU to readily check up whether the CAN bus is stuck at dominant or continuously disturbed and to monitor the proceeding of the Bus Off recovery sequence. Software initialization does not change conguration register values.

3.4 Conguration of Bit Timing


After setting bits Init and CCE in the CAN Control Register, the bit timing can be congured by writing to the Bit Timing Registers. - 17/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

While Bit Timing Register 0 controls the (Re)Synchronisation Jump Width and the Baud Rate Prescaler, Bit Timing Register 1 is used to dene the position of the Sample Point inside a Bit Time. For a detailed description how to program the bit timing see chapter 4.14.

3.5 Silent Mode


The CAN Controller can be set in Silent Mode by programming the Bus Conguration Register bits DcR1 and DcR0 both to one and PEn to zero. In Silent Mode, the CC770 is able to receive valid data frames and valid remote frames, but it sends only recessive bits on the CAN bus and it cannot start a transmission. If the CAN Controller is required to send a dominant bit (ACK bit, overload ag, active error ag), the bit is rerouted internally so that the CAN Controller monitors this dominant bit, although the CAN bus may remain in recessive state. The Silent Mode can be used to analyze the trafc on a CAN bus without affecting it by the transmission of dominant bits (Acknowledge Bits, Error Frames).

3.6 Low Current Modes


Power Down and Sleep Modes are activated by the PwD and Sleep bits in the CPU Interface Register (02H) under the control of the programmer. During Power Down and Sleep Mode the CPU Interface Register is the only accessible register. In these modes the oscillator is not active and no access to the message objects is possible. The CC770 immediately enters Power Down Mode after the PwD bit in the CPU Interface Register (bit 4, register 02H) is set, regardless of a possibly ongoing transmission on the CAN Bus. The CC770 exits from Power Down by either a hardware reset or by resetting the PwD bit to "0". The CPU must read the hardware reset bit (bit 7, register 02H) to ensure the CC770 has exited Power Down. The CC770 enters Sleep Mode after the Sleep bit in the CPU Interface Register (bit 3, register 02H) is set and a possibly ongoing transmission on the CAN Bus has nished. Sleep mode is exited by resetting the Sleep bit or when there is activity on the CAN bus. The CC770 requires a minimum of tPU to come out of Sleep Mode after bus activity occurs to ensure the oscillator and the PLL is stable, see chapter 8.4.1. Power Down and Sleep Mode should not be entered directly after reset. The user program must perform a minimum Memory conguration at any time (preferably during the initialization) prior to entering these modes. Programming the following registers satises the minimum conguration requirement: Control Register (00H) CPU Interface Register (02H) Bit Timing Register 0 (3FH) Bit Timing Register 1 (4FH) All MO Control 0 Registers Control Register (00H) (set CCE bit to "1") (DMC bit application specic) (application specic) (application specic) (reset MsgVal bit to "0") (reset Init and CCE bits to "0")

- 18/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

4. Functional Description
This section explains the functional operation of the CC770 by describing the registers used to congure the chip and Message Objects.

4.1 CC770 Address Map


The CC770 allocates an address space of 256 bytes. All registers are organized as 8-bit registers.

Address 00H 01H 02H 03H 04+05H 06+07H 08-0BH 0C-0FH 10-1EH 1FH 20-2EH 2FH 30-3EH 3FH 40-4EH 4FH 50-5EH 5FH 60-6EH 6FH 70-7EH 7FH

Register Control Status CPU Interface reserved High Speed Read Global Mask - Standard Global Mask - Extended Message 15 Mask Message 1 ClkOut * Message 2 Bus Conguration * Message 3 Bit Timing 0 * Message 4 Bit Timing 1 * Message 5 Interrupt Message 6 Receive Error Counter Message 7 Transmit Error Counter

Table 5: CC770 address map

- 19/85 14.09.2010 BOSCH Common_FunctionalDescription.fm Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 Address 80-8EH 8FH 90-9EH 9FH A0-AEH AFH B0-BEH BFH C0-CEH CFH D0-DEH DFH E0-EEH EFH F0-FEH FFH Register Message 8 reserved Message 9 P1CONF * Message 10 P2CONF * Message 11 P1IN Message 12 P2IN Message 13 P1OUT Message 14 P2OUT Message 15

Data Sheet

Rev. 1.8

Serial Reset Address

Table 5: CC770 address map

NOTE:
* The

CPU may write to the Conguration Registers only if the CCE bit is "1" (Control Regis-

ter).

4.2 Control Register (00H)


7 res rw 6 CCE rw 5 EAF rw 4 res r 3 EIE rw 2 SIE rw 1 IE rw 0 Init rw

The default value of the Control Register after a hardware reset is 01H. Reserved bits read as "0" and must be written as "0".

- 20/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 CCE Change Conguration Enable one

Data Sheet

Rev. 1.8

The CPU has write access to the Conguration Registers (ClkOut, Bus Conguration,...). Init bit should be set in order to stop CAN bus activities, if the values in the Bit Timing Registers must be changed. The CPU has no write access to the Conguration Registers.

zero

This bit is reset by the CPU to provide protection against unintentional rewriting of critical registers by the CPU following the initialization sequence. EAF Enable Additional Functions one The Receive Error Counter (address 6FH) and the Transmit Error Counter (address 7FH) can be read. The additional mask bits MDir and MXtd in the Message 15 Mask are enabled. The addresses 6FH and 7FH are reserved. The additional mask bits MDir and MXtd in the Message 15 Mask are disabled and will be read as 00, independent of the last value written to those bits while EAF was "1".

zero

The CC770 provides additional functions giving the programmer the possibility to read the Error Counters and to mask Xtd and Dir bits in the Message 15 Mask, allowing the reception of all possible messages not received by other Message Objects. To enable this functions the programmer has to set the EAF bit. EIE Error Interrupt Enable one Error interrupts enabled. A change in the error status of the CC770 (Boff or Warn changes from 0 to 1 or vice versa from 1 to 0) will cause an interrupt to be generated. Error interrupts disabled. No error interrupt will be generated.

zero

Error interrupts are BOff and Warn in the Status Register. Error Interrupt Enable is set by the CPU to allow the CC770 to interrupt CPU when an abnormal number of CAN bus errors have been detected. It is recommended to enable this interrupt during normal operation. SIE Status Change Interrupt Enable one Status Change Interrupt enabled. An interrupt will be generated when a CAN bus error is detected in the Status Register or a transfer (reception or transmission) is successfully completed, independent of the interrupt enable bits in any Message Object. Status Change Interrupt disabled. No status interrupt will be generated.

zero

Status Change Interrupts are WakeUp, RxOK, TxOK, and LEC0-2 in the Status Register. RxOK occurs upon every successful message transmission on the CAN bus, regardless of whether the message is stored by the CC770. The LEC bits are very helpful to indicate whether Bit or Form Errors are occurring. In normal operation it is not advised to enable this interrupt for LEC since the CAN protocol was designed to handle these error conditions in hardware by error frames and the automatic - 21/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

retransmission of messages. When cumulative LEC occur, the warning and BusOff ags will be set. The Error Interrupt should be enabled to detect these conditions. In most applications, the SIE bit should not be set. Since this interrupt will occur for every message, the CPU will be unnecessarily burdened. Instead, interrupts should be implemented on a Message Object basis so interrupts occur only for messages that are used by the CPU. The SIE bit is set by the CPU. NOTE: If the Status Change Interrupts and Message Object receive/transmit interrupts are enabled, there will be two interrupts for each message successfully received or transmitted by a Message Object. IE Interrupt Output Enable one zero Interrupt Pin enabled. Interrupt Pin disabled. The CC770 will generate no interrupts although the Interrupt Register (5FH) will still be updated.

Applies to EIE, SIE, and Message Object Tx/Rx interrupts. For example the Interrupt Register (5FH) contains a value other than zero, indicating the interrupt source (Message Object or Status), and the IE bit is set to one, an interrupt will be generated. No interrupt will be lost because of periodic setting or resetting of this bit. The Interrupt Output Enable bit is set by the CPU. INIT Initialization one zero Software initialization is enabled. Software initialization is disabled.

Following a hardware reset, this bit will be set. The Init bit is written by the CPU and is set by the CC770 when it goes busoff. Initialization is a state which allows the user to congure the CC770 Memory without the chip participating in any CAN bus transmissions. While Init equals one, all message transfers to and from the CAN bus are stopped, and the status of the CAN bus output Tx is recessive. Initialization will most often be used the rst time after power-up and when the CC770 has removed itself from the CAN bus after going busoff. Init should not be used in normal operation when the CPU is modifying transmit data; the CPUUpd bit in the Control 1 register from each Message Object is used in this case.

4.3 Status Register (01H)


7 BOff r 6 Warn r 5 WakeUp r 4 RxOK rw 3 TxOK rw 2 1 LEC rw 0

The default value of the Status Register after a hardware reset is undened. - 22/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

BOff Bus Off Status one zero There is an abnormal rate of occurrences of errors on the CAN bus. The CC770 is not busoff.

The Bus Off condition occurs when the Transmit Error Counter in the CC770 has reached the limit of 256. In consequence, the CC770 is going busoff. During busoff, no messages can be received or transmitted. When this ag changes, an interrupt will occur if the EIE and IE bits of the Control Register (00H) are set. The Bus Off Status bit is written by the CC770. Note: This bit represents the status of the CAN core (protocol FSM), thus when CC770 is in Bus Off state, this bit could only be reset by a successful processed busoff recovery sequence. By resetting the Init bit in the Control Register (location 00H), the busoff recovery sequence begins. The busoff recovery sequence resets the Transmit and Receive Error Counters. After the CC770 counts 129 packets of 11 consecutive recessive bits on the CAN bus, the busoff state is exited and BOff ag is reset. Warn Warning Status one zero There is an abnormal rate of occurrences of errors on the CAN bus. There is no abnormal occurrence of errors.

The Warning condition occurs when an error counter (REC or TEC) in the CC770 has reached the limit of 96. When this ag changes, an interrupt will occur if the EIE and IE bits of the Control Register (00H) are set. The Warning Status bit is written by the CC770. WakeUp Wake Up Status one zero The CC770 has left Power Down or Sleep mode. No wake up.

Setting the Sleep bit in CPU Interface register (02H) to "1" will place the CC770 into Sleep mode. While in Sleep mode, the WakeUp bit is "0". The WakeUp bit will become "1" when bus activity is detected or when the CPU writes the Sleep bit to "0". The WakeUp bit will also be set to "1" after the CC770 comes out of Power Down mode. The WakeUp bit and WakeUp interrupt is reset by reading the Status Register. This bit is written by the CC770. RxOK Receive Message Successfully one zero Since this bit was last reset to zero by the CPU, a message has been successfully received. Since this bit was last reset by the CPU, no message has been successfully received.

This bit is never reset by the CC770. A successfully received message may be any CAN - 23/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

bus transmission that is error-free, regardless of whether the CC770 has congured a Message Object to receive that particular message identier. The CC770 will set this bit, the CPU may clear it. TxOK Transmit Message Successfully one zero Since this bit was last reset to zero by the CPU, a message has been successfully transmitted (error free and acknowledged by at least one other node). Since this bit was last reset by the CPU, no message has been successfully transmitted.

This bit is never reset by the CC770. The CC770 will set this bit, the CPU may clear it. LEC Last Error Code 0 1 No error Stuff Error More than 5 equal bits in a sequence have occurred in a part of a received message where this is not allowed. 2 3 Form Error The xed format part of a received frame has the wrong format. Acknowledgment Error (AckError) The message transmitted by this device was not acknowledged by another node. 4 Bit 1 Error During the transmission of a message (with the exception of the arbitration eld), the CC770 wanted to send a recessive level (bit of logical value 1), but the monitored CAN bus value was dominant. 5 Bit 0 Error During the transmission of a message, the CC770 wanted to send a dominant level (bit of logical value 0), but the monitored CAN bus value was recessive. During busoff recovery, this status is set each time a recessive bit is received (indicating the CAN bus is not stuck dominant). 6 CRC Error The CRC checksum was incorrect in the message received. The CRC received for an incoming message does not match with the CRC value calculated by this device for the received data. 7 Unused

This eld contains a code which indicates the type of the rst error to occur in a frame on the CAN bus. If a message has been transferred (reception or transmission) without error, this eld will be cleared to 0. The code 7 is unused and may be written by the CPU to check for updates. - 24/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 4.3.1 Status Interrupts

Data Sheet

Rev. 1.8

If the SIE bit in the Control Register (00H) is set and the CC770 has updated the Status Register, the Interrupt Register (5FH) will contain a "1". The Status Register must be read if a Status Change Interrupt occurs. Reading the Status Register will clear the Status Change Interrupt. A Status Change Interrupt will occur on every successful reception or transmission, regardless of the state of the RxOK and TxOK bits. Therefore, if TxOK is set and a subsequent transmission occurs, an interrupt will occur (if enabled) even though TxOK was previously equal to one. There are two ways to implement the receive and transmit interrupt handling. The rst method uses the TxIE and RxIE bits in the Control 0 register of each Message Object. Whenever a message is transmitted or received by a Message Object, the Interrupt register (5FH) points to the interrupt source with the highest priority, e.g. the message object with the rx/tx event. If the IE bit of register 00H is set, the CC770 interrupt line gets active. This interrupt handling requires a minimal CPU intervention and is therefore recommended for almost all applications. The second method is based on the CC770 status interrupts. Setting the SIE bit of the Control register (00H) to "1" will generate an interrupt whenever a successful message transmission or reception occurs. The TxOK bit will be set when any of the Message Objects transmits a message. The RxOK bit will be set on any successfully received message. This may be any CAN bus transmission that is error-free, regardless of whether the CC770 has congured a Message Object to receive that particular message identier. This method allows the software to react on any CAN transmission sent over the CAN bus, which could be useful e.g. for CAN bus analysers. Due to the very high interrupt rate, this method is not recommended for standard CAN applications.

4.4 CPU Interface Register (02H)


7 RstST r 6 DSC rw 5 DMC rw 4 PwD rw 3 Sleep rw 2 MUX rw 1 StEn rw 0 CEn rw

The value of the CPU Interface Register during the hardware reset is E1H, after the end of the hardware reset the default value is 61H. RstSt Hardware Reset Status one The hardware reset of the CC770 is active (RESET is low). While reset is active, no access to the CC770 is possible, except read access on the CPU interface register. Normal operation.

zero

The CPU must ensure this bit is zero before further access to the CC770 after reset. This bit is written by the CC770. DSC Divide System Clock (SCLK). one The system clock is equal to XTAL/2.

- 25/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 zero

Data Sheet The system clock is equal to XTAL.

Rev. 1.8

This bit is written by the CPU. DMC Divide Memory Clock (MCLK) one zero The memory clock is equal to SCLK/2. The memory clock is equal to SCLK.

This bit is written by the CPU. PwD Power Down Mode enable and Sleep Mode enable PwD 0 0 1 Sleep 0 1 X Function Both Power Down and Sleep Modes are not active. Sleep Mode is active. These bits are written by the CPU. Power Down Mode is active.

Table 6: Function of Power Down and Sleep bits

Information about low Current Modes see chapter 3.6. The Sleep bit and the Power Down bit may be set and reset by the CPU. The Sleep bit will also be reset by CAN bus activity during Sleep Mode. MUX (see text below) one zero LQFP44: Pin 18 = oat, pin 5 = INT#. PLCC44: Pin 24 = oat, pin 11 = INT#. Normal operation: LQFP44: Pin 18 = INT#, pin 5 = P2.6. PLCC44: Pin 24 = INT#, pin 11 = P2.6.

This bit is written by the CPU. Bit 2 (MUX) controls whether the interrupt output is available at pin P2.6/INT# (MUX = 1) or pin INT# (MUX = 0). The CC770 lets pin INT# oat if MUX = 1. StEn Clockout Stretch Enable one The Clockout for the CPU is stretched to lengthen the read and write cycles of the CC770 instead of generating wait states. Example: CPU read data from CC770 When the CPU writes the address byte to the CC770 the Clockout is disabled, until the data of the selected address is available for read. The Clockout is not streched. Clockout signal is enabled, (default after reset). Clockout signal is disabled.

zero one zero

CEn Clockout enable

- 26/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Accesses to the CPU Interface Register are asynchronous, so it is possible to read and write this register even if there is no clock input or during Power Down Mode and Sleep Mode. 4.4.1 Clocking Description There are two analogue clocks and four digital clocks in the CC770. The analogue clocks are the crystal oscillator clock (XTAL) and the PLL clock (PLLCLK). The digital clocks are the system clock (SCLK), the memory clock (MCLK), the CLOCKOUT pin signal, and the SPI clock (SPICLK). While the SPI clock is directly controlled by the SPI master, the other digital clocks are derived from the analogue clocks. The PLLCLK (two times the frequency of XTAL) is provided as clock source for SCLK in order to allow a sufcient system clock frequency SCLK for high CAN bit rates at a moderate XTAL frequency. The balanced two-phase clock SCLK is always the result of a divideby-2; CPU Interface Register's bit DSC decides whether the PLL (DSC="0", SCLK=XTAL) or XTAL (DSC=1, SCLK=XTAL/2) is the source of SCLK. SCLK is the clock of the CAN's bit timing and other CAN protocol functions. The memory clock MCLK is derived from SCLK, it is either the same as SCLK (DMC=0) or it is SCLK/2 (DMC=1), compensating for the limited clocking range of the CC770's Content Addressable Memory (CAM). The CLOCKOUT pin signal is always derived from PLLCLK, its actual frequency is controlled by the CDv value in the ClkOut register (1FH). If the CLOCKOUT pin is not used and the SCLK frequency is sufcient at XTAL/2, then the PLL should be disabled in order to reduce the CC770's electromagnetic interference (EMI). This is done by setting DSC="1", StEn="1", and CEn="0". When the PLL is enabled, the minimum XTAL frequency is 8 MHz. Since the CC770's design is fully static, the XTAL frequency may be lower than 8 MHz when the crystal at the XTAL pins is replaced by a clock generator and the PLL is disabled.

fXTAL 8 MHz 10 MHz 12 MHz 16 MHz 20 MHz

SCLK 8 MHz 10 MHz 6 MHz 8 MHz 10 MHz

MCLK 8 MHz 5 MHz 6 MHz 8 MHz 5 MHz

DSC bit 0 0 1 1 1

DMC bit 0 1 0 0 1

Table 7: Maximum MCLK frequency for various oscillator frequencies

Notes: Frequency of SCLK = fXTAL/(1 + DSC bit) Frequency of MCLK = fSCLK/(1 + DMC bit) = fXTAL/[(1 + DSC bit) * (1 + DMC bit)]

- 27/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

4.5 High Speed Read Register (04+05H)


High Speed Read Register (04H) 7 6 5 4 3 2 1 0

Low Byte r

High Speed Read Register (05H) 7 6 5 4 3 2 1 0

High Byte r The value of the High Speed Read register is not affected by a hardware reset. The High Speed Read register is a read only register and is the output buffer for the CPU Interface Logic. This register is part of the CPU Interface Logic and is not located in the RAM. During a read to the RAM (low speed registers) this register is loaded with the value of the low speed register being accessed. The High Speed Read register is available to provide a method to read the CC770 when the CPU (host microcontroller) is unable to satisfy read cycle timings for low speed CC770 registers. In other words, if the read access time of the CC770 is too slow for the CPU and the CPU cannot extend the read bus cycle, the following double read method should be used. Note: The double read method does not avoid the wait time after preceding read or write, see ACtiming parameters tRLDV1, tEHDV, and tCLDV. This wait time is to be interposed between the two accesses. 4.5.1 Double Read Operation The CPU can execute double reads where the rst read addresses the low speed register and the second read addresses the High Speed Read register. The rst read is a dummy read for the CPU, however the low speed register value is stored in the High Speed Read register. The second read to the High Speed Read register will provide the data from the desired low speed register. The advantage of double reads is both read operations have fast access times. The rst read of the low speed register requires 40 ns (verify in current data sheet) to load the High Speed Read Register (the data on the address/data pins is not valid). The second read of the High Speed Read register requires 55 ns (verify in current data sheet) and the data on the address/data bus is valid. Therefore, if the access time of a low speed register is too long for the CPU then a second - 28/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

read to the High Speed Register will produce the correct data. Please note Low and High Speed registers have different access timing specications in the CC770 data sheet. During a 16-bit read access the low and high byte will contain the 16-bit value from the read access. For an 8-bit read access the low byte will contain the value from the read access.

4.6 Global Mask - Standard Register (06-07H)


Global Mask (06H) 7 Msk28 rw 6 Msk27 rw 5 Msk26 rw 4 Msk25 rw 3 Msk24 rw 2 Msk23 rw 1 Msk22 rw 0 Msk21 rw

Global Mask (07H) 7 Msk20 rw 6 Msk19 rw 5 Msk18 rw 4 3 2 res r 1 0

The value of the Global Mask Standard is not affected by a hardware reset. Reserved bits read as "1". Mskx Mask bit at position X one zero must-match (incoming bit value must match to the corresponding bit in the Arbitration Register from a Message Object) dont care (accept a "0" or "1" for that bit position)

The Global Mask Standard register applies only to messages using the standard CAN Identier and thereby to Message Objects with the Xtd bit set to "0". This feature, also called message acceptance ltering, allows the user to Globally Mask, or dont care any identier bits of the incoming message. This mask is programmable to allow the user to develop an application specic masking strategy. Note: When a remote frame is sent, an CC770 receiver node will use the Global Mask Registers to determine whether the remote frame matches to any of its Message Objects. If the CC770 is programmed to transmit a message in response to a remote frame message identier, the CC770 will transmit a message with the message identier of the CC770 Message Object. The result is the remote message and the responding CC770 transmit message may have different message identiers because some CC770 Global Mask Register bits are "dont care".

- 29/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

4.7 Global Mask - Extended Register (08-0BH)


Global Mask Extended (08H) 7 Msk28 rw 6 Msk27 rw 5 Msk26 rw 4 Msk25 rw 3 Msk24 rw 2 Msk23 rw 1 Msk22 rw 0 Msk21 rw

Global Mask Extended (09H) 7 Msk20 rw 6 Msk19 rw 5 Msk18 rw 4 Msk17 rw 3 Msk16 rw 2 Msk15 rw 1 Msk14 rw 0 Msk13 rw

Global Mask Extended (0AH) 7 Msk12 rw 6 Msk11 rw 5 Msk10 rw 4 Msk9 rw 3 Msk8 rw 2 Msk7 rw 1 Msk6 rw 0 Msk5 rw

Global Mask Extended (0BH) 7 Msk4 rw 6 Msk3 rw 5 Msk2 rw 4 Msk1 rw 3 Msk0 rw 2 1 res r 0

The value of the Global Mask Extended is not affected by a hardware reset. Reserved bits read as "0". Mskx Mask bit at position x one zero must-match (incoming bit value must match to the corresponding bit in the Arbitration Register from a Message Object) dont care (accept a "0" or "1" for that bit position)

The Global Mask extended register applies only to messages using the extended CAN identier and thereby to Message Objects with the Xtd bit set to "1". This feature allows the user to Globally Mask, or dont care, any identier bits of the incoming message. This mask is programmable to allow the user the develop an application specic masking strategy. Note: When a remote frame is sent, an CC770 receiver node will use its Global Mask Registers to - 30/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

determine whether the remote frame matches to any of its Message Objects. If the CC770 is programmed to transmit a message in response to a remote frame message identier, the CC770 will transmit a message with the message identier of the CC770 Message Object. The result is the remote message and the responding CC770 transmit message may have different message identiers because some CC770 Global Mask Register bits are "dont care".

4.8 Acceptance Filtering Implications


The CC770 implements two acceptance masks which allow Message Objects to receive messages with a range of message identiers (IDs) instead of just a single message ID. This provides the application the exibility to receive a wide assortment of messages from the bus. The CC770 observes all messages on the CAN bus and stores any message that matches a messages ID programmed into an active Message Object. It is possible to dene which message ID bits must identically match those programmed in the Message Objects to store the message. Therefore, ID bits of incoming messages are either must-match or dontcare. By dening bits to be dont-care, Message Objects will receive multiple message IDs.

4.9 Message 15 Mask Register (0C-0FH)


Message 15 Mask Register (0CH) 7 Msk28 rw 6 Msk27 rw 5 Msk26 rw 4 Msk25 rw 3 Msk24 rw 2 Msk23 rw 1 Msk22 rw 0 Msk21 rw

Message 15 Mask Register (0DH) 7 Msk20 rw 6 Msk19 rw 5 Msk18 rw 4 Msk17 rw 3 Msk16 rw 2 Msk15 rw 1 Msk14 rw 0 Msk13 rw

Message 15 Mask Register (0EH) 7 Msk12 rw 6 Msk11 rw 5 Msk10 rw 4 Msk9 rw 3 Msk8 rw 2 Msk7 rw 1 Msk6 rw 0 Msk5 rw

- 31/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 Message 15 Mask Register (0FH) 7 Msk4 rw 6 Msk3 rw 5 Msk2 rw 4 Msk1 rw

Data Sheet

Rev. 1.8

3 Msk0 rw

2 MDir rw

1 MXtd rw

0 res r

The value of the Message 15 Mask is not affected by a hardware reset. Reserved bit read as "0". Mskx Mask bit at position X one zero must-match (incoming bit value must match to the corresponding bit in the Arbitration Register from the Message Object 15) dont care (accept a "0" or "1" for that bit position)

MDir Mask Direction Bit (EAF must be set, see note) one zero must-match (incoming Direction bit value must match to the corresponding bit in the Arbitration Register from the Message Object 15) dont care (Message Object 15 accepts Remote and Data Frames)

MXtd Mask Extended Bit (EAF must be set, see note) one zero Notes: The Message 15 Mask Register is a programmable local mask. This feature allows the user to locally mask, or dont care, any identier bits of the incoming message for Message Object 15. Incoming messages are rst checked for an acceptance match in Message Objects 1- 14 before passing through to Message Object 15. Consequently, the Global Mask and the Local Mask apply to messages received in Message Object 15 in that way, that Message 15 Mask is ANDed with the Global Mask. This means that any bit dened as dont-care in the Global Mask will automatically be a dont care bit for message 15. For the receive-only Message Object 15, it is also possible to mask the bits Dir and Xtd, allowing the reception of Standard and Extended as well as Data and Remote Frames in this Message Object. To enable the MDir and MXtd bits the EAF bit has to be set in the Control Register 00H. If EAF="0", the additional mask bits MDir and MXtd in the Message 15 Mask Register are disabled and the bits will be read as "00", independent of the last value written to those bits while EAF was set. The internal interpretation is "11", so the bits Dir and Xtd must match for acceptance ltering. must-match (incoming Xtd bit value must match to the corresponding bit in the Arbitration Register from the Message Object 15) dont care (Message Object 15 accepts Standard and Extended Identier Frames)

- 32/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

4.10 ClkOut Register (1FH)


7 0 r 6 0 r 5 SL1 rw 4 SL0 rw 3 2 CDv rw 1 0

The default value of the ClkOut Register after a hardware reset is 00H (Modes 0 and 1 and serial mode) or 01H (Modes 2 and 3). The ClkOut register controls the frequency of the ClkOut signal as well as the slew rate. The default frequency of ClkOut depends on the CPU interface mode. For Modes 0, 1 and serial mode the default frequency is XTAL. For Modes 2 and 3 the default frequency is XTAL/2. The following tables list the programmable ClkOut frequencies and the slew rates:

CDv 0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111

ClkOut Frequency XTAL XTAL/2 XTAL/3 XTAL/4 XTAL/5 XTAL/6 XTAL/7 XTAL/8 XTAL/9 XTAL/10 XTAL/11 XTAL/12 XTAL/13 XTAL/14 XTAL/15 Reserved

Table 8: Programming ClkOut

- 33/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

SL1 0 0 1 1

SL0 0 1 0 1

slew rate fast medium to fast medium to slow slow

Table 9: Programming ClkOut slew rates

Note: The SL0/1 bits adjusts the driving current of the CLKOUT pin. So the resulting slew rate also depends on the external capacitance of the CLKOUT circuit. Therefore the optimum conguration of the SL0/1 bits is application specic, EMI requirements have to be regarded.

4.11 Bus Conguration Register (2FH)


7 res rw 6 PEn rw 5 Pol rw 4 res rw 3 DcT1 rw 2 res r 1 DcR1 rw 0 DcR0 rw

The default value of the bus Conguration Register after a hardware reset is 00H. Reserved bit 2 read as "0". PEn Polarity Switch Enable one zero Polarity switch Pol is enabled. Silent Mode is not functional. Polarity switch Pol is disabled. Bit Pol has no function.

Pol Polarity Switch one zero A logical one is interpreted as dominant and a logical zero is recessive on the Rx0 input, if PEn is set and DcR0 is not set. A logical one is interpreted as recessive and a logical zero is dominant bit on the Rx0 input.

DcT1 Disconnect TX1 output one zero TX1 output driver disabled, recommended for applications with bus driver ICs. TX1 output driver enabled.

- 34/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 DcR1 Silent Mode one zero

Data Sheet

Rev. 1.8

Silent Mode is active, if DcR0 bit is set and PEn is zero. Normal operation.

In Silent Mode, the CC770 is able to receive valid data frames and valid remote frames, but it sends only recessive bits on the CAN Bus and it cannot start a transmission. Rx0 is used as non inverted CAN input. The polarity switch Pol has no function in silent mode. For additional Information, see chapter 3.5. DcR0 Select Rx input one zero Notes: To be compatible to other CAN controllers, the reserved bits 7 and 4 remain writeable. Rx1 is enabled and used as inverted CAN input, if PEn is not set. Rx0 is enabled and used as non inverted CAN input.

4.12 Receive Error Counter (6FH)


7 EP r 6 5 4 3 REC6-0 r 2 1 0

The default value of the Receive Error Counter after a hardware reset is 00H. EP Error Passive one zero At least one of the error counters (REC or TEC) has reached the error passive level as dened in the CAN specication. Both error counters are below the error passive level.

REC6-0 Receive Error Counter Actual state of the Receive Error Counter. Values between 0 and 127. Note: The Receive Error Counter is only readable, if the EAF bit is set in the Control Register. Otherwise EP and REC6-0 are reserved bits.

4.13 Transmit Error Counter (7FH)


7 6 5 4 TEC7-0 r The default value of the Transmit Error Counter after a hardware reset is 00H. - 35/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights. 3 2 1 0

CC770 TEC7-0 Transmit Error Counter

Data Sheet

Rev. 1.8

Actual state of the Transmit Error Counter. Values between 0 and 255. Note: The Transmit Error Counter is only readable, if the EAF bit is set in the Control Register. Otherwise TEC7-0 are reserved bits.

- 36/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

4.14 Bit Timing Registers


4.14.1 Bit Timing Overview A CAN message consists of a series of bits that are transmitted in consecutive bit times. A bit time accounts for propagation delay of the bit, CAN chip input and output delay, and synchronization tolerances. This section describes components of a bit time from the perspective of the CAN Specication and the CC770. According to the CAN Specication, the nominal bit time is composed of four time segments. These time segments are separate and non-overlapping as shown below: NOMINAL BIT TIME SYNC_SEG PROP_SEG PHASE_SEG1 PHASE_SEG2

SAMPLE POINT
Figure 3: Time Segments of Bit Time

TRANSMIT

SYNC_SEG Synchronisation Segment This part of the bit time is used to synchronize the various nodes on the bus. An edge is expected to lie within this segment. PROP_SEG Propagation Time Segment This part of the bit time is used to compensate for the physical delay times within the network. It is twice the sum of the signals propagation time on the bus line, the input comparator delay and the output driver delay. NOTE: The factor of two accounts arbitration which requires nodes consecutively to synchronize to different transmitters. PHASE_SEG1, PHASE_SEG2: Phase Buffer Segment1,2 These segments are used to compensate for edge phase errors and can be lengthened or shortened by resynchronization. SAMPLE POINT: The sample point is the point of time at which the bus level is read and interpreted as the value of that respective bit. Its location is at the end of PHASE_SEG1. 4.14.2 CC770 Bit Timing Denitions In this application, the Synchronisation Segment is represented by tSync, the Phase Buffer - 37/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Segment2 is represented by tTSeg2, while tTSeg1 is the summation of the Propagation Time Segment and the Phase Buffer Segment1. The preceding gure represents a bit time from the perspective of the CC770. A bit time is subdivided into time quanta. One time quantum is derived from the System Clock (SCLK) and the Baud Rate Prescaler (BRP). Each segment is a multiple of the Time Quantum tq. The length of these segments is programmable, with the exception of the Synchronisation Segment, which is always 1 tq long.

1 bit time

tSyncSeg

tTSeg1

tTSeg2

tSyncSeg

1 time quantum ( tq )
Figure 4: Bit Timing

Sample Point

Transmit Point

4.14.3 CC770 Bit Time Segments The following are relationships of the CC770 bit timing: bit time= tSyncSeg + tTSeg1 + tTSeg2 (see preceding gure) tSyncSeg = 1 tq tTSeg1 = ( TSeg1 + 1 ) tq tTSeg2 = ( TSeg2 + 1 ) tq tq = ( BRP + 1 ) tSCLK fBit = fXTAL / [(DSC + 1) (BRP + 1) (TSeg1 + TSeg2 + 3)] The DSC bit is programmed in the CPU Interface Register, the variables TSeg1, TSeg2, and Baud Rate Prescaler BRP are the programmed numerical values from the Bit Timing Registers. The actual interpretation by the hardware of these values is such that one more than the values programmed here is used, as shown in the brackets from the equations. 4.14.4 Calculation of the Bit Time The programming of the bit time has to regard the CAN Specication Rev. 2.0 and depends on the desired baudrate, the CC770 oscillator frequency fXTAL and on the external physical delay times of the bus driver, of the bus line and of the input comparator. The delay times are summarised in the Propagation Time Segment, its actual value tProp is:

- 38/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

tProp is two times the maximum of the sum of physical bus delay, the input comparator delay, and the output driver delay rounded up to the nearest multiple of tq. To full the requirements of the CAN specication, the following conditions must be met : tTSeg2 1 tq = Information Processing Time

tTSeg2 tSJW

tTSeg1 2 tq

tTSeg1 tSJW + tProp

tTSeg1 tSJW + tProp + 2tq Note:

for 3 Sample Mode (bit Spl="1" in register 4FH)

In order to achieve correct operation according to the CAN protocol the total bit time should be at least 8 tq, i.e. TSeg1 + TSeg2 5 (as programmed in the Bit Timing Register 1). To operate with a baudrate of 1 MBit/s, the frequency of SCLK has to be at least 8 MHz, in consequence fXTAL has to be at least 16 MHz. The maximum tolerance df for XTAL depends on the Phase Buffer Segment1 (PB1), the Phase Buffer Segment2 (PB2), and the Resynchronisation Jump Width (SJW):

df AND df

min ( PB 1, PB 2 ) ---------------------------------------------------------------2 ( 13 bit time PB 2 ) SJW ------------------------------20 bit time

(PB1 = tTSeg1 - tProp ; PB2 = tTSeg2)

- 39/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

4.14.5 Example for Bit Timing at high Baudrate Conguration: fXTAL = 20 MHz, fSCLK = 10MHz (DSC=1), BRP = 0, bitrate should be 1 MBit/s. tq delay of bus driver delay of receiver circuit delay of bus line (40m) tProp tSJW tTSeg1 tTSeg2 tSync-Seg bit time 100 50 30 220 600 100 700 200 100 1000 ns ns ns ns ns ns ns ns ns ns = tSCLK = tXTAL 2

= 520 ns, round up = 6 tq = 1 tq = tProp + tSJW = Information Processing Time + 1 tq = 1 tq (fix) = tSync-Seg + tTSeg1 + tTSeg2

min ( PB 1, PB 2 ) = --------------------------------------------------------------2 ( 13 bit time PB2 ) 0.1s = ----------------------------------------------------------2 ( 13 1s 0.2s ) In this example, the Bit Timing Registers must be programmed with the following values: maximal oscillator tolerance 0.39 % Bit Timing Register 0 (3FH): 00H Bit Timing Register 1 (4FH): 16H 4.14.6 Bit Timing Registers 0 + 1 (3FH + 4FH) Bit Timing Registers are used to dene the CAN bus frequency, the sample point within a bit time, and the mode of synchronization. Bit Timing Register 0 (3FH) 7 SJW rw 6 5 4 3 BRP rw 2 1 0

The default value of the Bit Timing Register 0 after a hardware reset is 00H.

SJW (Re) Synchronization Jump Width The valid programmed values are 0-3. The SJW denes the maximum number of time quanta a bit time may be shortened or lengthened by one resynchronization. The actual interpretation of this value by the hardware is to use one more than the programmed value. - 40/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 BRP Baud Rate Prescaler

Data Sheet

Rev. 1.8

The valid programmed values are 0-63. The baud rate prescaler programs the length of one time quantum as follows: tq = tSCLK (BRP + 1) where tSCLK is the period of the system clock (SCLK). Bit Timing Register 1 (4FH) 7 Spl rw 6 5 TSeg2 rw 4 3 2 TSeg1 rw 1 0

The default value of the Bit Timing Register 1 after a hardware reset is 00H. Spl Sampling Mode one zero The CAN bus is sampled three times per bit time for determining the valid bit value using majority logic. Bus is sampled once, may result in faster bit transmissions rates.

Sampling mode = "0" may result in faster bit transmissions rates, while sampling mode = "1" is more immune to noise spikes on the CAN bus. TSeg2 Time Segment 2 The valid programmed values are 0-7. TSeg2 is the time segment after the sample point. The actual interpretation of this value by the hardware is one more than the value programmed by the user. TSeg1 Time Segment 1 The valid programmed values are 1-15. TSeg1 is the time segment before the sample point. The actual interpretation of this value by the hardware is one more than the value programmed by the user.

4.15 Interrupt Register (5FH)


7 6 5 4 IntId r The default value of the Interrupt Register after a hardware reset is 00H. - 41/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights. 3 2 1 0

CC770 IntId Interrupt Identier

Data Sheet

Rev. 1.8

The Interrupt Register is a read-only register. The value in this register indicates the source of the interrupt. When no interrupt is pending, this register holds the value "0". If the SIE bit in the Control Register (00H) is set and the CC770 has updated the Status Register, the Interrupt Register will contain a "1". This indicates an interrupt is pending due to a change in the Status Register. The value 2 + Message Object Number indicates the IntPnd bit in the corresponding Message Object is set. There is an exception in that Message Object 15 will have the value 2, giving Message Object 15 the highest priority of all Message Objects.

Interrupt Source none Status Register Message Object 15 Message Object 1 Message Object 2 Message Object 3 Message Object 4 Message Object 5 Message Object 6 Message Object 7 Message Object 8 Message Object 9 Message Object 10 Message Object 11 Message Object 12 Message Object 13 Message Object 14

Value 00H 01H 02H 03H 04H 05H 06H 07H 08H 09H 0AH 0BH 0CH 0DH 0EH 0FH 10H

Table 10: Interrupt Register values with corresponding Interrupt Sources

For example, a message is received by Message Object 13 with the IE (Control Register) and RxIE (Message Object 13 Control 0 Register) bits set. The interrupt pin will be pulled low and the value 15 (0FH) will be placed in the Interrupt Register. If the value of the Interrupt Register equals "1", then the Status Register at location 01H must be read to update this Interrupt Register. The Status Change Interrupt has a higher priority than interrupts from the Message Objects. Register 5FH is automatically set to "0" or to the lowest value corresponding to a Message Object with IntPnd set. When the value of this register is two or more, the IntPnd bit of the corresponding Message Object Control Register is set. - 42/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

The CC770 will respond to each status change event independently and will not bundle interrupt events in a single interrupt signal. However, if two status change events occur before the rst is acknowledged by the CPU, the next event will not generate a separate interrupt output. Therefore, when servicing Status Change Interrupts, the user code should check all useful status bits upon each Status Change Interrupt. After resetting the IntPnd bit in the Control 0 Register of individual Message Objects, the minimum delay of the CC770 resetting the interrupt pin and updating the Interrupt Register (5FH) is 3 MCLK cycles and a maximum of 14 MCLK cycles (after the CPU write operation to this register is nished). When a Status Change Interrupt occurs, reading the Status Register (01H) will reset the interrupt pin in a maximum of 4 MCLK cycles + 145 ns. Clearing the IntPnd bit of the Message Object will deactivate the INT# pin.

4.16 Serial Reset Address (FFH)


7 6 5 4 3 2 1 0

Serial Reset Address w The serial reset address is used to synchronize accesses between the CC770 and the CPU. For example the CPU cannot provide a chip select signal, it is possible to write as many ones into the CC770 SPI until you get the value "AAH" from the MISO pin. Then the CC770 is synchronized and data transfer could be started. For further informations see chapter 7.4.

4.17 CC770 Message Objects (MO)


4.17.1 Message Object Structure The Message Object is the means of communication between the host microcontoller and the CAN controller in the CC770. Message Objects are congured to transmit or receive messages. There are 15 Message Objects located at xed addresses in the CC770. Each Message Object starts at a base address that is a multiple of 16 bytes and uses 15 consecutive bytes. For example, Message Object 1 starts at address 10H and ends at address 1EH. The remaining byte in the 16 byte eld is used for other CC770 functions. In the above example the byte at address 1FH is used for the ClkOut register. Message Object 15 is a receive-only Message Object that uses a local mask called the Message 15 Mask Register. This mask allows a large number of infrequent messages to be received by the CC770. In addition, Message Object 15 is buffered to allow the CPU more time to receive messages.

- 43/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Address Base Address +0 +1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14

Function Control 0 Control 1 Arbitration 0 Arbitration 1 Arbitration 2 Arbitration 3 Conguration Data 0 Data 1 Data 2 Data 3 Data 4 Data 5 Data 6 Data 7

Table 11: Message Object Structure

4.17.2 Control 0 + 1 Registers Control 0 Register (Base Address + 0) 7 MsgVal rw 6 5 TxIE rw 4 3 RxIE rw 2 1 IntPnd rw 0

Control 1 Register (Base Address + 1) 7 RmtPnd rw 6 5 TxRqst rw 4 3 2 1 NewDat rw 0

MsgLst/CPUUpd rw

The values of the Control 0 and Control 1 registers are not affected by a hardware reset. Each bit in the Control 0 and Control 1 bytes occurs twice; once in true form and once in - 44/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

complement form. This bit representation makes testing and setting these bits as efcient as possible. The advantage of this bit representation is to allow write access to single bits of the byte, leaving the other bits unchanged without the need to perform a read/modify/write cycle. For example, a CPU would set the TxRqst bit of the Control 1 byte with the following instructions: ... MO_CTRL1.REQU ... LDA STA #$EF ;set TxRqst of Message Object 1 MO_CTRL1.R; #0011;Message Object 1 Control 1 register

The representation of these two bits is described below: Direction Write MSB 0 0 1 1 Read 0 1 LSB 0 1 0 1 1 0 Meaning not allowed (indeterminate) reset set unchanged reset set

Table 12: Representation of bit pairs in Control Registers

MsgVal Message Valid set The Message Object is valid. reset The Message Object is invalid. The MsgVal ag is an individual halt ag for each Message Object. While this ag is reset the CC770 will not access this Message Object for any reason. This ag may be reset at any time if the message is no longer required, or if the identier is being changed. If a message identier is changed, the Message Object must be made invalid rst, and it is not necessary to reset the chip following this modication. The CPU must reset the MsgVal ag of all unused messages during initialization of the CC770 before the Init bit of the Control Register (00H) is reset. The contents of Message Objects may be recongured dynamically during operation and the MsgVal ag assists reconguration in many cases. The MsgVal ag must be set to indicate the Message Object is congured and is ready for communication transactions. This ag is written by the CPU. IMPORTANT NOTE: - 45/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Two or more Message Objects must not have the same message identier and also be valid at the same time! If more than one CC770 transmit Message Object has the same message ID, a successful transmission of the higher numbered Message Objects will not be recognized by the CC770. The lower numbered Message Object will be falsely identied as the transmit Message Object and its transmit request ag will be reset. The actual transmit Message Object will re-transmit without end because its transmit request ag will not be reset. This could result in a catastrophic condition since the higher numbered Message Object may dominate the CAN bus by resending its message without end. To avoid this condition, applications should require all transmit Message Objects to use message IDs that are unique. If this is not possible, the application should disable lower numbered Message Objects with similar message IDs until the higher numbered Message Object has transmitted successfully.

TxIE Transmit Interrupt Enable set An interrupt will be generated after a successful transmission of a frame. reset No interrupt will be generated after a successful transmission of a frame. The Transmit Interrupt Enable ag enables the CC770 to initiate an interrupt after the successful transmission by the corresponding Message Object. This ag is written by the CPU. RxIE Receive Interrupt Enable set An interrupt will be generated after a successful reception of a frame. reset No interrupt will be generated after a successful reception of a frame. This ag enables the CC770 to initiate an interrupt after the successful reception by the corresponding Message Object. This ag is written by the CPU. NOTE: In order for TxIE or RxIE to generate an interrupt, IE in the Control Register must be set. IntPnd Interrupt Pending set This Message Object has generated an interrupt. reset No interrupt was generated by this Message Object since the last time the CPU cleared this ag. This ag is set by the CC770 following a successful transmission or reception as controlled by the RxIE and TxIE ags. The CPU must clear this ag when servicing the interrupt.

RmtPnd Remote Request Pending - 46/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 set

Data Sheet

Rev. 1.8

The transmission of this Message Object has been requested by a remote node and is not yet done.

reset There is no waiting remote request for the Message Object. This ag is only used by Message Objects with direction = transmit. This ag is set by the CC770 after receiving a remote frame which matches its message identier, taking into account the Global Mask Register. The corresponding Message Object will respond by transmitting a message, if the CPUUpd ag is reset. Following this transmission, the CC770 will clear the RmtPnd ag. In other words, when this ag is set it indicates a remote node has requested data and this request is still pending because the data has not yet been transmitted. NOTE: Setting RmtPnd will not cause a remote frame to be transmitted. The TxRqst ag is used to send a remote frame from a receive Message Object.

TxRqst Transmit Request set The transmission of this Message Object has been requested and has not been completed.

reset This Message Object is not waiting to be transmitted. This ag is set by the CPU to indicate the Message Object data should be transmitted. Setting TxRqst will send a data frame for a transmit Message Object and a remote frame for a receive Message Object. If direction = receive a remote frame is sent to request a remote node to send the corresponding data. TxRqst is also set by the CC770 (at the same time as RmtPnd in Message Objects whose direction = transmit) when it receives a remote frame from another node requesting this data. This ag is cleared by the CC770 along with RmtPnd when the message has been successfully transmitted, if the NewDat ag has not been set.

MsgLst Message Lost Only valid for Message Objects with direction = receive. set The CC770 has stored a new message in this Message Object when NewDat was still set.

reset No message was lost since the last time this ag was reset by the CPU. This ag is used to signal that the CC770 stored a new message into this Message Object when the NewDat ag was still set. Therefore, this ag is set if the CPU did not process the contents of this Message Object since the last time the CC770 set the NewDat ag; this indicates the last message received by this Message Object overwrote the previous message which was not read and is lost. This denition is only valid for Message Objects with direction = receive. For Message Objects with direction = transmit, the denition is replaced by CPUUpd.

- 47/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 CPUUpd CPU Updating

Data Sheet

Rev. 1.8

Only valid for Message Objects with direction = transmit. set This Message Object may not be transmitted. reset This Message Object may be transmitted, if direction = transmit. The CPU sets this ag to indicate it is updating the data contents of the Message Object and the message should not be transmitted until this ag has been reset. The CPU indicates message updating has been completed by resetting this ag (it is not necessary to use the MsgVal ag to update the Message Objects data contents). The purpose of this ag is to prevent a remote frame from triggering a transmission of invalid data. NewDat New Data set The CC770 or CPU has written new data into the data section of this Message Object.

reset No new data has been written into the data section of this Message Object since the last time this ag was cleared by the CPU. This ag has different meanings for receive and transmit Message Objects. 4.17.3 Handling of Message Objects For Message Objects with direction = receive, the CC770 sets the NewDat ag whenever new data has been written into the Message Object. When the received data is written into Message Objects 1-14, the unused data bytes will be overwritten with non-specied values. The CPU should clear the NewDat ag before reading the received data and then check if the ag remained cleared when all bytes have been read. If the NewDat ag is set, the CPU should re-read the received data to prevent working with a combination of old and new data. See ow diagram in chapter 6.4. When the received Data is matched to Message Object 15, new data is written into the shadow register. The foreground register is not over-written with new data. For Message Object 15 messages, the data should be read rst, the IntPnd reset, and then the NewDat and RmtPnd ags are reset. Resetting the NewDat and RmtPnd ags before resetting the IntPnd ag will result the interrupt line remaining active. See ow diagram in chapter 6.5. For Message Objects with direction = transmit, the CPU should set the NewDat ag to indicate it has updated the message contents. This is done at the same time the CPU clears the CPUUpd ag. This will ensure that if the message is actually being transmitted during the time the message was being updated by the CPU, the CC770 will not reset the TxRqst ag. In this way, the TxRqst ag is reset only after the actual data has been transferred. See ow diagram in chapter 6.3. Each ag in the Control 0 and Control 1 registers may be set and reset by the CPU as required.

- 48/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Conditions required to trigger a transmission: Flags Init MsgVal TxRqst MsgLst/CPUUpd NewDat Dir Register Control MO-Control 0 MO-Control 1 MO-Control 1 MO-Control 1 MO-Conguration dont care 0 Remote Frame 0 set set reset should be set 1 Data Frame

Table 13: Bit combinations to start transmissions

NOTES: To initiate a transmission, the Control Register 1 of the Message Object should have the TxRqst and NewDat ags set to "1". Therefore, this register may be written with the value 066H. A remote frame may be received, an interrupt ag set, and no data frame transmitted in response by conguring a Message Object in the following manner. Set the CPUUpd and RxIE ags in the Message Object Control Register to "1". Set the Dir bit in the Message Conguration Register to "1". A remote frame will be received by this Message Object, the IntPnd ag will be set to "1" and no data frame will be sent in response. Message Object Priority If multiple Message Objects are waiting to transmit, the CC770 will rst transmit the message from the lowest numbered Message Object, regardless of message identier priority. If two Message Objects are capable of receiving the same message (possibly due to message ltering strategies), the message will be received by the lowest numbered Message Object. For example, if all acceptance mask bits were set as dont care, Message Object 1 will receive all messages. 4.17.4 Arbitration 0, 1, 2, 3 Registers Arbitration 0 (Base Address + 2): 7 ID28 rw 6 ID27 rw 5 ID26 rw 4 ID25 rw 3 ID24 rw 2 ID23 rw 1 ID22 rw 0 ID21 rw

Arbitration 1 (Base Address + 3): 7 ID20 rw 6 ID19 rw 5 ID18 rw 4 ID17 rw 3 ID16 rw 2 ID15 rw 1 ID14 rw 0 ID13 rw

- 49/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 Arbitration 2 (Base Address + 4): 7 ID12 rw 6 ID11 rw 5 ID10 rw 4 ID9 rw

Data Sheet

Rev. 1.8

3 ID8 rw

2 ID7 rw

1 ID6 rw

0 ID5 rw

Arbitration 3 (Base Address + 5): 7 ID4 rw 6 ID3 rw 5 ID2 rw 4 ID1 rw 3 ID0 rw 2 1 res r 0

The values of the Arbitration registers are not affected by a hardware reset. Reserved bits read as "0". ID0-ID28 Message Identier ID0-ID28 is the identier for an extended frame. ID18-ID28 is the identier for a standard frame. NOTE: When the CC770 receives a message, the entire message identier, the Data Length Code (DLC), the Direction bit (Dir) and the Extended Identier bit (Xtd) are stored (additionally to the data section) into the corresponding Message Object.

4.17.5 Conguration Register Conguration (Base Address + 6): 7 6 DLC rw 5 4 3 Dir rw 2 Xtd rw 1 res r 0

The value of the Conguration register is not affected by a hardware reset. Reserved bits read as "0".

- 50/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 DLC Data Length Code

Data Sheet

Rev. 1.8

The valid programmed values are 0-8. The Data Length Code of a Message Object is written with the value corresponding to the data length. Dir Direction one zero Direction = transmit. When TxRqst is set, the Message Object will be transmitted. Direction = receive. When TxRqst is set, a remote frame will be transmitted. When a message is received with a matching identier, the message will be stored in the Message Object.

Xtd Extended Identier one zero This Message Object will use an extended 29 bit message identier. This Message Object will use a standard 11 bit message identier.

If the Message Conguration Register bit Xtd is "0" to specify a standard frame, the CC770 will reset the extended bits in the Arbitration Registers (arbitration bits 0-17) to "0" whenever a data frame is stored in this message object. An extended receive Message Object (Xtd = "1") will not receive standard messages (except if this bit is masked out, which is possible for Message Object 15 only). If a Message Object receives a data frame from the CAN bus, the entire message identier, the Data Length Code (DLC), the Direction bit (Dir) and the Extended Identier bit (Xtd) are stored (additionally to the data section) into this Message Object. Therefore, if acceptance ltering (masking registers) is used, the masked-off "dont care" bits will be rewritten corresponding to the message ID of the incoming message. 4.17.6 Data Bytes Data Bytes (Base Address + 7 ... Base Address + 14): 7 6 5 4 3 2 1 0

data bytes 0,1,2,3,4,5,6,7 rw The values of the data byte 0-7 registers are not affected by a hardware reset. When the CC770 writes new data into the message buffer, only the data bytes dened by the DLC are valid. Unused data bytes will be overwritten by non-specied values.

- 51/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

4.18 Special Treatment of Message Object 15


Message Object 15 is a receive-only Message Object with a programmable local mask called the Message 15 Mask Register. Since this Message Object is a receive only Message Object, the TxRqst and the TxIE ags have been hardwired inactive and the CPUUpd ag has no meaning. The incoming messages for Message Object 15 will be written into a two-message alternating buffers to avoid the loss of a message if a second message is received before the CPU has read the rst message. Once Message Object 15 is read, it is necessary to reset the NewDat and the RmtPnd ags to allow the CPU to read the shadow message buffer which will receive the next message or which may already contain a new message. If two messages have been received by Message Object 15, the rst will be accessible to the CPU. The alternate buffer will be overwritten if a subsequent (third receive) message is received. Once again, after reading message 15, the user program should reset the IntPnd ag followed by a reset of the NewDat and RmtPnd ags in the Message Object Control Registers. The Xtd bit in the Message Conguration Register determines whether a standard or an extended frame will be received by this Message Object. This bit could be masked out, see chapter 4.9.

- 52/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

5. Port Registers
5.1 Port 1 Registers
P1CONF (9FH) 7 6 5 4 3 2 1 0

P1CONF 0-7 rw The default value of the P1CONF register after a hardware reset is 00H. P1CONF 0-7 Port 1 Input/Output Conguration bits one zero Port pin congured as a push-pull output. Port pin congured as a high-impedance input.

Port pins are weakly held high until this register has been written. P1IN (BFH) 7 6 5 4 3 2 1 0

P1IN 0-7 rw The default value of the P1IN register after a hardware reset is FFH. P1IN 0-7 Port 1 Data In one zero A one (high voltage) is read from the pin. A zero (low voltage) is read from the pin.

P1OUT (DFH) 7 6 5 4 3 2 1 0

P1OUT 0-7 rw The default value of the P1OUT register after a hardware reset is 00H. P1OUT 0-7 Port 1 Data Out one zero A logical one (high voltage) is written to the pin. A logical zero (low voltage) is written to the pin.

- 53/85 14.09.2010 BOSCH Common_PortRegisters.fm Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

5.2 Port 2 Registers


P2CONF (AFH) 7 6 5 4 3 2 1 0

P2CONF 0-7 rw The default value of the P2CONF register after a hardware reset is 00H. P2CONF 0-7 Port 2 Input/Output Conguration bits one zero Port pin congured as a push-pull output. Port pin congured as a high-impedance input.

Port pins are weakly held high until this register has been written. P2IN (CFH) 7 6 5 4 3 2 1 0

P2IN 0-7 rw The default value of the P2IN register after a hardware reset is FFH. P2IN 0-7 Port 2 Data In one zero A one (high voltage) is read from the pin. A zero (low voltage) is read from the pin.

P2OUT (EFH) 7 6 5 4 3 2 1 0

P2OUT 0-7 rw The default value of the P2OUT register after a hardware reset is 00H. P2OUT 0-7 Port 2 Data Out one zero A logical one (high voltage) is written to the pin. A logical zero (low voltage) is written to the pin.

- 54/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

6. FLOW DIAGRAMS
The following owcharts describe the operation of the CC770 and suggested ows for the host-CPU.

6.1 CC770 handling of Message Objects 1-14 (Transmit)


These are the operations the CC770 executes to transmit Message Objects. This diagram is useful to identify when the CC770 sets bits in the Control Registers.

DATA
yes

REMOTE bus free ?


no

no

TxRqst=1 CPUUpd=0
yes

received remote frame with matching identifier ?


yes

no

NewDat := 0 load message into shift register

TxRqst := 1 RmtPnd := 1

send message RxIE = 1


yes no

no

transmission successful?
yes no

IntPnd := 1

NewDat=1
yes

TxRqst := 0 RmtPnd := 0

no

TxIE = 1
yes

IntPnd := 1

Figure 5: CC770 handling of Message Objects 1-14 (Transmit)

- 55/85 14.09.2010 BOSCH Common_FlowDiagrams.fm Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

6.2 CC770 handling of Message Objects 1-14 (Receive)


These are the operations the CC770 executes to receive Message Objects. This diagram is useful to identify when the CC770 sets bits in the Control Registers.

REMOTE
yes

DATA bus idle ?


no

no

TxRqst=1 MsgLst =0
yes

received frame with matching identifier to this message object ?


yes

no

NewDat := 0 load identifier and control into shift register

send remote frame

NewDat = 1
no

yes

MsgLst := 1

no

transmission successful?
yes

TxRqst := 0 RmtPnd := 0

store message NewDat := 1 TxRqst := 0 RmtPnd := 0

no

TxIE = 1
yes

TxIE = 1
yes

no

IntPnd := 1

IntPnd := 1

Figure 6: CC770 handling of Message Objects 1-14 (Direction = Receive)

- 56/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

6.3 CPU Handling of Message Objects 1-14 (Transmit)


These are the operations the host-CPU executes to transmit Message Objects 1-14. Power Up ( reset values )

Initialisation

TxIE := ( application specific ) RxIE := ( application specific ) IntPnd := 0 RmtPnd := 0 TxRqst := 0 CPUUpd := 1 NewDat := 0 Identifier := ( application specific ) DLC := ( application specific ) Dir := transmit Xtd := ( application specific ) MsgVal := 1

CPUUpd := 1

Update Data Field

write data bytes

CPUUpd := 0 NewDat := 1

no

want to sent ?
yes

TxRqst := 1

no

update message ?
yes

Figure 7: CPU Handling of Message Objects 1-14 (Transmit)

- 57/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

6.4 CPU Handling of Message Objects 1-14 (Receive)


These are the operations the host-CPU executes to receive Message Objects 1-14.

Power Up

( reset values )

Initialisation

TxIE := ( application specific ) RxIE := ( application specific ) IntPnd := 0 RmtPnd := 0 TxRqst := 0 MsgLst := 0 NewDat := 0 Identifier := ( application specific ) DLC := ( dont care ) Dir := receive Xtd := ( application specific ) MsgVal := 1

no

NewDat =1 ?
yes no

NewDat := 0

request update ?
yes

read message Process Messages

TxRqst := 1

no

NewDat =0 ?
yes

process message

Figure 8: CPU Handling of Message Objects 1-14 (Receive)

- 58/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

6.5 CPU Handling of Message Object 15 (Receive)


These are the operations the host-CPU executes to receive Message Object 15. Power Up ( reset values )

RxIE := ( application specific ) IntPnd := 0 RmtPnd := 0 MsgLst := 0 NewDat := 0 Initialisation Message 15 Mask :=(application specific) Identifier := ( application specific ) DLC := ( dont care ) Dir := receive Xtd := ( application specific ) MsgVal := 1

no

New Dat = 1 ?
yes

Process Message

read and process message

IntPnd := 0

Toggle to alternative buffer

NewDat := 0 RmtPnd := 0

Figure 9: CPU Handling of Message Object 15 (Receive)

- 59/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

7. CPU Interface Logic


The CIL (CPU Interface Logic) is a exible interface between the CPU and the CC770 RAM. The CIL allows a direct serial interface or parallel interface connection to the CC770 for most commonly used CPUs. Therefore it converts serial or parallel address/control/data signals from the CPU into parallel read and write accesses to the internal memory bus. The internal memory bus is a non-multiplexed parallel bus that is used by both the CIL and the CAN Controller to read and write to the Message Memory.

7.1 CPU Interface Description


There are ve CPU interface modes used to interface a CPU to the CC770. These include four parallel interface modes (mode 0 to mode 3) and one serial interface mode (SPI). While RESET# is active, the two mode pins (MODE0, MODE1) select one of the following interface modes:

MODE1 0

MODE0 0

Interface Mode Mode 0: 8-bit multiplexed architecture with RD# & WR#. If both RD# and WR# are driven low during reset, the SPI mode is selected instead of Mode 0. Mode 1: 16-bit multiplexed architecture Mode 2: 8-bit multiplexed architecture with E & R/W# Mode 3: 8-bit non-multiplexed architecture

0 1 1

1 0 1

Table 14: CPU interface modes

Note: The MODE0 and MODE1 inputs are weakly pulled low while RESET# is active, but they have high impedance after reset. Therefore they must be driven to a valid logical value after reset.

7.2 Parallel Interfacing Techniques


Mode 0 Mode 0 is intended to interface controllers using pins ALE, RD#, WR# to control an 8-bit multiplexed address/data bus. A READY output is provided to force wait states in the CPU. Mode 1 Mode 1 is intended to interface controllers using pins ALE, RD#, WR# to control an 16-bit multiplexed address/data bus. A READY output is provided to force wait states in the CPU. Mode 2 Mode 2 is intended to interface controllers using pins AS, E, R/W# to control an 8-bit multiplexed address/data bus. A READY output is provided to force wait states in the CPU. - 60/85 14.09.2010 BOSCH Common_CPUInterfaceLogic.fm Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 Mode 3

Data Sheet

Rev. 1.8

Mode 3 is intended to interface to controllers using an 8-bit non-multiplexed address/data bus. The asynchronous mode uses R/W#, CS#, and DSACK0# (E=1). The synchronous mode uses R/W#, CS#, and E. Mode 3 uses the address/data bus as the address bus and Port 1 as the data bus. For CPUs which do not provide a READY or DSACK0# input and do not meet the address/ data bus timing restrictions, a double read mechanism must be used. When writing to the CC770 the programmer must ensure that the time between two consecutive write accesses is not less than two memory clock (MCLK) cycles. When reading the CC770, a double read is programmed. The rst read will be to the message object memory address and the second read will be to the High Speed Read register (04H, 05H). After the rst CPU read access, the CC770 stores the data contents to the High Speed Read register for the second read.

7.3 Serial Interface Techniques


The serial interface on the CC770 is fully compatible to the SPI protocol of Motorola and will interface to most commonly used serial interfaces. The serial interface is implemented in slave mode only, and responds to the master using the specially designed serial interface protocol. This serial interface allows an interconnection of several CPUs and peripherals on the same circuit board.

MOSI MISO CPU (master) SPICLK CS#

MOSI MISO CC770 SPICLK (slave) CS#

Figure 10: Interconnection for serial communication

MOSI: Master Out Slave In The MOSI pin is the data output of the master device (CPU) and the data input of the slave device (CC770). Data is transferred serially from the master to the slave on the signal line, with the most signicant bit rst and least signicant bit last. MISO: Master In Slave Out The MISO pin is the data output of the slave device (CC770) and the input of the master device (CPU). Data is transferred serially from the slave to the master on the signal line, with the most signicant bit rst and least signicant bit last. CS#: Chip Select (used as Slave Select for the SPI interface) An asserted state on the slave select input (CS#) enables the CC770 to accept data on the MOSI pin. The CS# must not toggle during data transfer. The CC770 will only drive data to the serial data register if CS# is at asserted state. - 61/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 SPICLK: Serial Clock

Data Sheet

Rev. 1.8

The master device provides the serial clock for the slave device. Data is transferred synchronously to this clock in both directions. The master and the slave devices exchange a data byte during a sequence of eight clock pulses.

7.4 Serial Interface Protocol


The general format of the data exchange from the CC770 to the master is a bit-for-bit exchange on each SPICLK clock pulse. Bit exchanges in multiples of 8 bits and up to 15 bytes of data are allowed. A maximum of 17 bytes can be send to the CC770-SPI, including one address byte, one SPI Control Byte, and 15 data bytes. At the beginning of a transmission over the serial interface, the rst byte will be the address of the CC770 special function register or the CC770 RAM to be accessed. The next byte transmitted is a Control Byte, which contains the number of bytes to be transmitted and whether this is to be a read or write access to the CC770. These rst two bytes are followed by the data bytes (1 to 15). To ensure the CC770 device is not out of synchronization, the CC770 will transmit the values "AAH" and then "55H" through the MISO pin while the master transmits the Address and Control Byte. The master may check for the reception of these bytes. If the master did not receive the rst synchronization byte ("AAH"), the Data transmitted since the last reception of the synchronization bytes are invalid. The CPU should abort the actual transmission. The CC770 can be re-synchronised by transmitting an FFH byte (SPI Reset Address). If the master receives the rst synchronization byte ("AAH") but not the second one ("55H"), the transmission of the address was disturbed. The CPU should abort the actual transmission in order to prevent data loss through transmission or reception of data from wrong addresses. The CC770 can be re-synchronised by transmitting an FFH byte (SPI Reset Address). When the SPI receives an Address or Control byte with the value FFH, the SPI interface will be reset. In this case, the SPI will assume the next byte is an address. AD0 (ICP) Idle Clock Polarity one zero SPICLK is idle high. SPICLK is idle low.

AD1 (CP) Clock Phase one zero Data sampled on the falling edge of SPICLK (ICP = 0) or data is sampled on the rising edge of SPICLK (ICP = 1). Data is sampled on the rising edge of SPICLK (ICP = 0) or data is sampled on the falling edge of SPICLK (ICP = 1).

AD2 (CSAS) Chip select active state one zero Asserted state of CS# is logic high. Asserted state of CS# is logic low.

- 62/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

AD3 (STE) Synchronization Transmission Enable one zero The rst two bytes which will be sent to the CPU after CS# is asserted are AAH and 55H. The rst two bytes which will be sent to the CPU after CS# is asserted are 00H and 00H.

Enables the transmission of the synchronization bytes while the Address and Control Bytes are transferred. sample points ICP 0 0 1 1 CP 0 1 0 1

MSB
Figure 11: Serial data communication

LSB

7.5 Serial Control Byte


The Serial Control Byte is transmitted by the CPU to the CC770 as follows: 7 Dir 6 5 Sync 4 3 2 SDLC 1 0

Dir Serial transmission direction zero one The data bytes will be read, so the CC770 will transfer information to the CPU. The data bytes will be sent from the CPU to the CC770.

Sync Synchronisation These three bits must always be sent as "000". SDLC Serial Data Length Code These four bits contains the number of bytes to be transmitted. Valid programmed values are 1-15. The rst data byte (third byte of the SPI protocol) will be written to or read from the CC770 address (rst byte of the SPI protocol). After this, the address is incremented by the SPI logic and the next data byte is written or read from this address. In one data stream, a max- 63/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

imum of 15 data bytes can be transferred. A DLC of zero is not allowed. After a DLC of zero is received, the SPI must be resynchronized. The SPI must also be resynchronized if one of the Synchronisation Bits was received as "1". When the CPU conducts a READ, the CPU sends an address byte and a Serial Control Byte. While the CC770 responds back with data, it ignores the MOSI pin (transmission from the CPU). The CPU may transmit the next address and Serial Control Byte after CS# is de-activated and then re-activated. This means the chip select should be activated and de-activated for each read or write transmission. Synchronization bytes must be monitored carefully. For example, if the CC770 does not transmit the AAH and 55H synchronization bytes correctly, then the previous transmission may be incorrect too. The MISO pin is tri-stated if CS# is inactive.

Vcc

Int Request Reset# CPU MOSI (master) MISO SPICLK CS# application specic Vss Vss Vss Vss

Int Request Reset# MOSI MISO SPICLK CS# CC770 AD0 (slave) AD1 AD2 AD3 RD# WR# XTAL1 XTAL2 MODE0 MODE1

Figure 12: CC770 SPI Interface Schematic

The MODE0 and MODE1 pins may be left open since they are weakly pulled low during reset.

- 64/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

8. Electrical Specication
8.1 Handling Instructions
Handle with extreme care. Pins should not be touched. Follow ESD (Electrostatic Discharge) protection procedure.

8.2 Absolute Maximum Ratings


Functional operation under any of these conditions is not implied. Operation beyond the limits in this table may impair the lifetime of the device. Parameter Maximum rise-time of Supply-Voltage Maximum Supply-Voltage (VCC-VSS) Maximum current at all inputs/outputs Protection of I/O against ESD (HBM) Storage temperature
Table 15: Absolute Maximum Ratings

Value 1 V/s - 0.5 V to +7.0 V 25 mA PLCC44: 800V (1.5 k,100 pF) LQFP44: 1000V (1.5 k,100 pF) PLCC44: -40C to +150C LQFP44: -50C to +150C

Cat* C C C C C

Note: For the conditions listed above the IC is protected against latch up effects. *Category: A B C Parameter measured as analog value in series test program. Parameter tested as go/nogo test in series test program. Characterized only or guaranteed by design.

8.3 D.C. Characteristics


Conditions: VCC = 5V 10%, Ambient Temperature TA = -40C to +125C Parameter VIL VIH VIH1 VOL Input Low Voltage Input High Voltage (All inputs except RESET#) Input High Voltage RESET# Hysteresis on RESET# Output Low Voltage Min -0.5 3.0 3.0 200 Max 0.8 VCC+0.5 VCC+0.5 0.45 Unit V V V mV V IOL = 1.6 mA Conditions Cat B B B A A

Table 16: D.C. Characteristics

- 65/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, C m o _ C aa t r t sf o m n E h r cesc .m ii editing, distribution, as well as in the event of applications for industrial property rights.

CC770 Parameter VOH ILK CIN ICC ISLEEP IPD Rpull Output High Voltage Input Leakage Current Pin Capacitance(1) Supply Current(2) Sleep Current, no Load(2) Power down Current(2) Pull resistor impedance(3)

Data Sheet

Rev. 1.8 Max Unit V 1 10 50 100 25 A pF mA A A k XTAL1 clocked Conditions IOH = -200 A VSS<VIN<VCC fXTAL = 1 kHz Cat A A C A A A C

Min VCC-0.8

15

Table 16: D.C. Characteristics

(1) Typical value based on characterization data. (2) All pins are driven to VSS or VCC, VCC = 5V, fXTAL = 16 MHz, fMCLK = 8 MHz (3) Pull down resistors for mode 0 and 1 pins and pull up resistors for port 1 and 2 pins.

8.4 A.C. Characteristics


The following A.C. characteristics are valid for these operating conditions: Ambient Temperature TA -40 to +125C Power supply VCC = 5V10%, VSS = 0V Pin load CL = 100 pF 8.4.1 A.C. Characteristics for start-up Symbol Parameter Min Max 1 ms tSU_PLL + tSU_OSC(2) 1 s tSU_PLL + tSU_OSC(2) Cat C C C C

tSU_PLL Start Up Time of PLL tCR tWR tPU Cold Reset Assertion Time(1) Warm Reset Assertion Time(3) Power Up from Sleep Mode(4)

Table 17: A.C. Characteristics for start-up

NOTES: 1. Cold reset means, that VCC is driven to a valid level while RESET# is asserted. In this case, RESET# must be driven low for tCR minimum (measured from a valid VCC level) to ensure the oscillator and the PLL are stable, see gure 13. No falling edge on the Reset pin is required during cold reset phase. 2. The start up time of the oscillator (tSU_OSC) is application specic and highly depends on the selected crystal respective the clock driver. The start up time of the oscillator may be different in the cases of hardware reset and power up from sleep mode. The times have to be determined as part of CC770 validation in the target application.

- 66/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

3. Warm reset means, that VCC remains valid while RESET# is asserted. In this case, RESET# must be driven to a low level for tWR minimum, see gure 13.
valid

VCC
RESET#

tCR

VCC

tWR

RESET# Cold Reset Warm Reset

Figure 13: Timing for CC770 reset

4. When the Low Current Mode is left (by writing to Interface Register bits Sleep or PwD, or by CAN activity in case of Sleep Mode), the CC770 may take up to tPU to come out of Sleep/PwD Mode (until restarted oscillator and PLL are stable), see chapter 3.6. 8.4.2 A.C. Characteristics for clocks Symbol 1/tXTAL 1/tSCLK 1/tMCLK tCOPD tCHCL Parameter Oscillator Frequency System Clock Frequency Memory Clock Frequency CLKOUT Period(2) CLKOUT High Period(2) Min 8 MHz(1) 4 MHz(1) 2 MHz(1)
(CDV(3)+1)0.5 tXTAL-10ns

Max 20 MHz 10 MHz 8 MHz


(CDV(3)+1) 0.5tXTAL+15ns

Cat B B B C C

(CDV(3) + 1) tXTAL

Table 18: A.C. Characteristics for clocks

NOTES: 1. The XTAL frequency may be lower than 8 MHz when the crystal at the XTAL pins is replaced by a clock generator and the PLL is disabled, see chapter 4.4. This implies, that the System and Memory clocks, which are derived from XTAL, will be lower accordingly. 2. Load at CLKOUT pin should not exceed 50 pF. 3. Denition of CDV is the value loaded in the CLKOUT register representing the CLKOUT divisor. 8.4.3 A.C. Characteristics for CAN interface Symbol tRx2Tx Parameter Internal delay Rx -> Tx Min Max 42 ns Cat B

Table 19: A.C. Characteristics for CAN interface

- 67/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

8.4.4 A.C. Characteristics for 8/16-Bit Multiplexed Modes (Modes 0, 1) Symbol tAVLL tLLAX tLHLL tLLRL tCLLL tQVWH tWHQX tWLWH tWHLH tWHCH tRLRH Parameter Address Valid to ALE Low Address Hold after ALE Low ALE High Time ALE Low to RD# Low CS# Low to ALE Low Data Setup to WR# High Input Data Hold after WR# high WR# Pulse Width WR# High to next ALE High WR# High to CS# High RD# Pulse Width
This time is long enough to initiate a double read cycle by loading the High Speed Registers (04H, 05H), but is too short to READ from 04H and 05H (See tRLDV)

Min 7.5 ns 10 ns 30 ns 20 ns 10 ns 27 ns 10 ns 30 ns 8 ns 0 ns 40 ns

Max

Conditions Cat B B B B B B B B B B B

tRLDV tRLDV1

RD# Low to Data Valid


(only for registers 02H, 04H, 05H)

0 ns

55 ns

B B

RD# Low Data to Data Valid


(for registers except 02H, 04H, 05H) Read Cycle without previous write (1) Read Cycle with previous write (1) 1.5tMCLK+100ns 3.5tMCLK+100ns

tRHDZ tCLYV

Data Float after RD# High CS# Low to READY Setup


Condition: Load Cap. on the READY output: 50 pF

0 ns

45 ns 32 ns 40 ns 145 ns
2tMCLK +100ns

B VOL=1.0V VOL=0.45V B

tWLYZ tWHYZ

WR# Low to READY Float


for a write cycle if no previous write is pending(2)

B B

End of Last Write to READY Float


for a write cycle if a previous write cycle is active(2)

tRLYZ

RD# Low to READY Float


(for registers except 02H, 04H, 05H) read cycle without previous write (1) read cycle with a previous write (1) 2tMCLK+100ns 4tMCLK+100ns

tWHDV

WR# High to Output Data Valid on port 1/2

tMCLK 2tMCLK+500ns

Table 20: A.C. Characteristics for 8/16-Bit Multiplexed Modes (Modes 0, 1)

- 68/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 NOTES:

Data Sheet

Rev. 1.8

In 16 bit mode, two CC770 addresses will be accessed in parallel. The high byte (AD15-8) contains the data related to the odd CC770 addresses and low byte (AD7-0) contains the data related to the even CC770 addresses. Therefore the LSB of the address is without function. The write access to the odd and even addresses is controlled by separate write select lines WRH# and WRL#, to enable byte and word accesses. The timing is equivalent to signal WR#. The read access is controlled by the single select line RD#, thus read accesses are always word accesses. 1. Denition of read cycle without a previous write: The time between the rising edge of WR#/WRH# (for the previous write cycle) and the falling edge of RD# (for the current read cycle) is greater than 2 tMCLK . 2. Denition of write cycle with a previous write: The time between the rising edge of WR#/WRH# (for the previous write cycle) and the rising edge of WR#/WRH# (for the current write cycle) is less than 2 tMCLK . .
tLHLL

ALE

tAVLL

tLLAX

BUS

Address
tRLDV

Data out
tRHDZ

RD#
tRLRH tWHCH

tCLLL

tLLRL

CS#
tWLWH tWHLH

WR#
tQVWH

tWHQX

BUS

Address

Data in
tWHDV

PORT1/2

Figure 14: Timing for 8/16-Bit Multiplexed Modes (Modes 0, 1)

- 69/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

CS#

WR#
tWLYZ

tCLYV

Ready

Figure 15: Ready Output Timing (write cycle, no previous write is pending)

CS#

WR#

tWHYZ

Ready

Figure 16: Ready Output Timing (write cycle, previous write cycle is active)

CS#
tCLYV

ALE

RD#

tRLYZ

Ready

Figure 17: Ready Output Timing for a Read Cycle

- 70/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

8.4.5 A.C. Characteristics for 8-Bit Multiplexed Mode 2 Symbol tAVSL tSLAX tELDZ tEHDV Parameter Address Valid to AS Low Address Hold after AS Low Data Float after E Low E High to Data Valid for registers 02H, 04H, 05H read cycle without a previous write (1) read cycle with a previous write (registers except for 02H, 04H, 05H) tQVEL tELQX tELDV tEHEL tELEL tSHSL tRSEH tSLEH tCLSL tELCH Data Setup to E Low Input Data Hold after E Low E Low to Output Data Valid port 1/2 E High Time End of previous write (Last E Low) to E Low for a write cycle AS High Time Setup Time of R/W# to E High AS Low to E High CS# Low to AS Low E Low to CS# High 30 ns 20 ns tMCLK 45 ns 2 tMCLK 30 ns 30 ns 20 ns 20 ns 0 ns 2tMCLK+500ns Min 7.5 ns 10 ns 0 ns 0 ns 45 ns 45 ns 1.5tMCLK+100ns 3 tMCLK+100ns Max Cat B B B B B

B B B B B B B B B B

Table 21: A.C. Characteristics for 8-Bit Multiplexed Mode 2

NOTES: 1. Denition of Read Cycle without a Previous Write: The time between the falling edge of E (for the previous write cycle) and the rising edge of E (for the current read cycle) is greater than 2 tMCLK .

- 71/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

tSHSL

AS

tAVSL

tSLAX

BUS

Address
tSLEH tEHDV

Data out
tELDZ

E
tEHEL tRSEH

R/W#
tELCH

tCLSL

CS#

R/W#
tQVEL tELQX

BUS

Address

Data in
tELDV

PORT1/2

Figure 18: Timing for 8-Bit Multiplexed Mode 2

- 72/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

8.4.6 A.C. Characteristics for 8-Bit Non-Multiplexed Asynchronous (Mode 3) Symbol tAVCL tCLDV Parameter Address or R/W# Valid to CS# Low Setup CS# Low to Data Valid for High Speed Registers (02H, 04H, 05H) For Low Speed Registers (Read Cycle without Previous Write) (1) For Low Speed Registers (Read Cycle with Previous Write) (1) tKLDV DSACK0# Low to Output Data Valid for High Speed Read Register For Low Speed Read Register tCHDV tCHDH tCHDZ tCHKH1 tCHKH2 tCHKZ tCHCL tCHAI tCHRI tCLCH tDVCH tCLKL CC770 Input Data Hold after CS# High CC770 Output Data Hold after CS# High CS# High to Output Data Float CS# High to DSACK0# = 2.4V (2) CS# High to DSACK0# = 2.8V CS# High to DSACK0# Float CS# Width between Successive Cycles CS# High to Address Invalid CS# High to R/W# Invalid CS# Width Low CPU Write Data Valid to CS# High
CS# Low to DSACK0# Low for High Speed Registers and Low Speed Registers Write Access without Previous Write (3)

Min 3ns 0 ns 0 ns 0 ns

Max

Cat B

55 ns
1.5 tMCLK +100 ns 3.5 tMCLK +100 ns

B B B B B B B

23 ns < 0 ns 15 ns 0 ns 35 ns 0 ns 55 ns 150 ns 0 ns 25 ns 7 ns 5 ns 65 ns 20 ns 0 ns 67 ns 100 ns

B B B B B B B B B B

tCHKL

End of previous write (CS# High) to DSACK0# Low for a write cycle with a previous write (3)

0 ns

2 tMCLK + 145 ns

Table 22: A.C. Characteristics for 8-Bit Non-Mux Asynchronous (Mode 3)

NOTES: E and AS must be tied high in this mode.

- 73/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

1. Denition of Read Cycle without a Previous Write: The time between the rising edge of CS# (for the previous write cycle) and the falling edge of CS# (for the current read cycle) is greater than 2 tMCLK . 2. An on-chip pullup will drive DSACK0# to approximately 2.4V. An external pullup is required to drive this signal to a higher voltage. 3. Denition of Write Cycle without a Previous Write: The time between the rising edge of CS# (for the previous write cycle) and the rising edge of CS# (for the current write cycle) is greater than 2 tMCLK .

Address
tCHAI

R/W#
tAVCL tCLCH tCHCL

CS#
tCHDZ tCLDV tCHDH

Data
tCLKL tKLDV tCHKZ tCHKH

DSACK0#

Figure 19: Timing for 8-Bit Non-Mux Asynchronous Mode (Mode 3), read cycle.

- 74/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Address
tCHAI

R/W#
tAVCL tCLCH tCHCL

CS#
tDVCH tCHDV

Data
tCLKL tCHKZ tCHKH

DSACK0#

Figure 20: Timing for 8-Bit Non-Mux-Async Mode (Mode 3), write cycle.

- 75/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

8.4.7 A.C. Characteristics for 8-Bit Non-Multiplexed Synchronous (Mode 3) Symbol tEHDV Parameter E High to Data Valid out of High Speed Register (02H, 04H, 05H) Read Cycle without previous write for Low Speed Registers (1) Read Cycle with previous write for Low Speed Registers (1) tELDH tELDZ tELDV tAVEH tELAV tCVEH tELCV tDVEL tEHEL tAVAV tAVCL tCHAI Data Hold after E Low for a read cycle Data Float after E Low Data Hold after E Low for a write cycle Address and R/W# to E setup Address and R/W# Valid after E falls CS# Valid to E High CS# Valid after E Low Data Setup to E Low E Active width Start of a write cycle after a previous Write Access Address or R/W# to CS# Low Setup CS# High to Address Invalid 15 ns 25 ns 15 ns 0 ns 0 ns 55 ns 100 ns 2 tMCLK 3 ns 7 ns 5 ns 35 ns Min Max 55 ns
1.5 tMCLK +100 ns 3.5 tMCLK +100 ns

Cat B B B B B B B B B B B B B B B

Table 23: A.C. Characteristics for 8-Bit Non-Mux Asynchronous (Mode 3)

NOTES: 1. Denition of Read Cycle without a Previous Write: The time between the falling edge of E (for the previous write cycle) and the rising edge of E (for the current read cycle) is greater than 2 tMCLK .

- 76/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 .
Address

Data Sheet

Rev. 1.8

tELAV

R/W#

tAVEH tAVCL tCVEH tELCV tCHAI

CS#
tEHEL

E
tEHDV tELDZ tELDH

Data

Figure 21: Timing for 8-Bit Non-Mux Synchronous Mode (Mode 3), read cycle.

tAVAV

Address
tELAV

R/W#
tAVEH tCVEH tELCV tCHAI

tAVCL

CS#
tEHEL

E
tDVEL tELDV

Data

Figure 22: Timing for 8-Bit Non-Mux Synchronous Mode (Mode 3), write cycle.

- 77/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

8.4.8 A.C. Characteristics for Serial Interface Mode Symbol fSPICLK tCYC tSKHI tSKLO tLEAD tLAG tACC tPDO tHO tDIS tSETUP tHOLD tRISE tFALL tCS Parameter SPI Clock Frequency 1/fSPICLK Clock High Time Clock Low Time Enable Lead Time Enable Lag Time Access Time Data Out Delay Time Data Out Hold Time Data Out Disable Time Data Setup Time Data Hold Time Input Rise Time Input Fall Time Chip Select High Time 125 25 25 45 45 0 125 Min 0.5 1/fMCLK 45 45 70 70 60 30 Max fMCLK 2000 Unit MHz ns ns ns ns ns ns ns ns ns ns ns ns ns ns Cat B B B B B B B B B B B B C C B

Table 24: A.C. Characteristics for Serial Interface Mode

- 78/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

tLEAD

tLAG

tCS

CS#
tRISE tSKHI tSKLO tCYC tFALL

SPICLK

tACC

tHO

tPD0

tDIS

MISO
tSETUP tHOLD

MOSI

Figure 23: Timing for Serial Interface Mode (Polarity=0,Phase=0)

tLEAD

tLAG

tCS

CS#
tFALL tSKLO tSKHI tCYC tRISE

SPICLK

tACC

tHO

tPDO

tDIS

MISO
tSETUP tHOLD

MOSI

Figure 24: Timing for Serial Interface Mode (Polarity=1,Phase=1)

- 79/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770 8.4.9 Waveforms for testing

Data Sheet

Rev. 1.8

VCC Input VSS Timing parameter

A.C. test inputs are driven at the VCC and VSS levels. A.C. test outputs are measured at 1/2 VCC. Input rise and fall times (10%/90%) < 10ns

Output

1/2VCC

Figure 25: Input and output reference waveforms

- 80/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

9. Errata
9.1 Interrupt update during Initialization Mode
9.1.1 Scope This erratum is only related to older steppings of the CC770, the latest F step1 is not affected by the issues described in this chapter. Furthermore, this erratum applies only to applications that use the interrupt register and interrupt pin. 9.1.2 Description The CC770s interrupt register is not updated while the Init bit (Initialization-Mode) is set. The contents of the interrupt register must be considered invalid until Init is cleared. Since the interrupt register may be frozen at a value /= 0x00, the Interrupt Enable bit IE needs to be cleared when Init is set, to avoid a continuous active level at the interrupt pin. 9.1.3 Work-around Apart from hardware reset, there are two possibilities how the Init bit can be set; either by software or by the event "Entering BusOff State". When Init is set by software, IE needs to be cleared by the same write-access to the CC770s control register. This will disable the Interrupt pin and does not change the internal interrupt state. When Init is set by the event "Entering BusOff State", the interrupt service routine needs to clear IE (this will disable the Interrupt pin and does not change the internal interrupt state), or it may alternatively clear Init, thereby also starting the BusOff Recovery Sequence.

1. CC770F: LQFP44 package (lead-free) 0 272 240 159 & PLCC44 package (lead-free) 0 272 240 160

- 81/85 14.09.2010 BOSCH DataSheet_Errata.fm Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Figure 1: Block Diagram of CC770. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 Figure 2: Package Diagrams of CC770 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Figure 3: Time Segments of Bit Time . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 Figure 4: Bit Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 Figure 5: CC770 handling of Message Objects 1-14 (Transmit) . . . . . . . . . . . . . . 55 Figure 6: CC770 handling of Message Objects 1-14 (Direction = Receive) . . . . . 56 Figure 7: CPU Handling of Message Objects 1-14 (Transmit) . . . . . . . . . . . . . . . 57 Figure 8: CPU Handling of Message Objects 1-14 (Receive) . . . . . . . . . . . . . . . . 58 Figure 9: CPU Handling of Message Object 15 (Receive) . . . . . . . . . . . . . . . . . . . 59 Figure 10: Interconnection for serial communication . . . . . . . . . . . . . . . . . . . . . . 61 Figure 11: Serial data communication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 Figure 12: CC770 SPI Interface Schematic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 Figure 13: Timing for CC770 reset. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 Figure 14: Timing for 8/16-Bit Multiplexed Modes (Modes 0, 1) . . . . . . . . . . . . . . 69 Figure 15: Ready Output Timing (write cycle, no previous write is pending) . . . 70 Figure 16: Ready Output Timing (write cycle, previous write cycle is active) . . 70 Figure 17: Ready Output Timing for a Read Cycle . . . . . . . . . . . . . . . . . . . . . . . . 70 Figure 18: Timing for 8-Bit Multiplexed Mode 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 Figure 19: Timing for 8-Bit Non-Mux Asynchronous Mode (Mode 3), read cycle. 74 Figure 20: Timing for 8-Bit Non-Mux-Async Mode (Mode 3), write cycle. . . . . . . 75 Figure 21: Timing for 8-Bit Non-Mux Synchronous Mode (Mode 3), read cycle. 77 Figure 22: Timing for 8-Bit Non-Mux Synchronous Mode (Mode 3), write cycle. 77 Figure 23: Timing for Serial Interface Mode (Polarity=0,Phase=0). . . . . . . . . . . . 79 Figure 24: Timing for Serial Interface Mode (Polarity=1,Phase=1). . . . . . . . . . . . 79 Figure 25: Input and output reference waveforms. . . . . . . . . . . . . . . . . . . . . . . . . 80

- 82/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Table 1: Pin description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Table 2: Multi Function Pins . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 Table 3: Reset values of CC770 registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 Table 4: Reset states of CC770 output pins . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 Table 5: CC770 address map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 Table 6: Function of Power Down and Sleep bits . . . . . . . . . . . . . . . . . . . . . . . . . . 26 Table 7: Maximum MCLK frequency for various oscillator frequencies . . . . . . . . 27 Table 8: Programming ClkOut . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 Table 9: Programming ClkOut slew rates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 Table 10: Interrupt Register values with corresponding Interrupt Sources . . . . . 42 Table 11: Message Object Structure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 Table 12: Representation of bit pairs in Control Registers . . . . . . . . . . . . . . . . . . 45 Table 13: Bit combinations to start transmissions . . . . . . . . . . . . . . . . . . . . . . . . . 49 Table 14: CPU interface modes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 Table 15: Absolute Maximum Ratings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 Table 16: D.C. Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 Table 17: A.C. Characteristics for start-up . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 Table 18: A.C. Characteristics for clocks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 Table 19: A.C. Characteristics for CAN interface . . . . . . . . . . . . . . . . . . . . . . . . . . 67 Table 20: A.C. Characteristics for 8/16-Bit Multiplexed Modes (Modes 0, 1) . . . . 68 Table 21: A.C. Characteristics for 8-Bit Multiplexed Mode 2 . . . . . . . . . . . . . . . . . 71 Table 22: A.C. Characteristics for 8-Bit Non-Mux Asynchronous (Mode 3) . . . . . 73 Table 23: A.C. Characteristics for 8-Bit Non-Mux Asynchronous (Mode 3) . . . . . 76 Table 24: A.C. Characteristics for Serial Interface Mode . . . . . . . . . . . . . . . . . . . . 78

- 83/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

10. Appendix
10.1 Documentation of Changes
10.1.1 Changes on Revisions
10.1.1.1 Revision 1.0

Initial version.
10.1.1.2 Revision 1.1

Specication left preliminary state. Protection against ESD reduced to 800 V. Timing parameters tCOPD and tCHCL are now categorized to C.
10.1.1.3 Revision 1.2

Package Diagram now more detailed. Clockout pin is active while reset is active, see chapter 3.2.2. Flare clocking limitations, see chapter 4.4.1. Behaviour of Serial Reset address, see chapter 4.16. Mode0/1 Pins must be connected in any conguration, see note in chapter 7.1 fSPICLK must not be higher than fMCLK, see chapter 8.4.8. Notes to the design steps B and C are not supported anymore.
10.1.1.4 Revision 1.3

Add errata description for CC770 with stepping D. Product number of package diagram modied.
10.1.1.5 Revision 1.4

Introduction of new LQFP44 package.


10.1.1.6 Revision 1.5

Add important information for DSACK pin wiring at the end of chapter 3.1. Correct table in chapter 3.2.2. The port 1 and 2 pull up resistors are not off but on directly after reset, according notes to pin descriptions at the end of chapter 3.1. Add information for entering power down, see chapter 3.6. Add further information to BOff and Warn status bits, see chapter 4.3. Better differentiation between CC770 interrupt methods, see chapter 4.3.1. Correct packet count value of Bus Off Recovery Sequence to 129, see chapter 4.3. Correct reset value of CPU Interface register, see chapter 4.4. Add information about tCLDV, see chapter 4.5. Correct timing for second read to High Speed register, see chapter 4.5.1. Add information about pull up control, see chapter 5. Correct description of the EP ag in Receive Error Counter (6FH). This bit does not ag the receive error passive only, but both receive and transmit error passive. Thus the ag was renamed to EP, see chapter 4.12. - 84/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, DataSheet_Appendix.fm editing, distribution, as well as in the event of applications for industrial property rights.

CC770

Data Sheet

Rev. 1.8

Add impedance of pull up and pull down resistors, see chapter 8.3. Add information to interface modes 0 & 1, see chapter 8.4. Add new chapter for a further erratum concerning all CC770 steps, see chapter 9.
10.1.1.7 Revision 1.6

Update of chapter chapter 9. according verication of work-around for BusOff erratum.


10.1.1.8 Revision 1.7

Renamed "BusOff" erratum to "Interrupt update during Initialization Mode" erratum (new name describes cause instead of effect) and alternative workaround proposed. Removed errata description for D-Step of CC770 from Data Sheet (this stepping was never shipped to external customers). Editorial changes. Added parameters for start-up, see chapter 8.4.1. Added parameter for internal Rx -> Tx delay, see chapter 8.4.3.
10.1.1.9 Revision 1.8

Updated revision history related to revision 1.7. Added ordering information for F-Step of CC770. Claried description of reserved bits in Bus Conguration Register, see chapter 4.11. Added description of bit 6 in Bus Conguration Register, see chapter 4.11. Added information about the inuence of bit 6 on Silent Mode, see chapter 3.5 and chapter 4.11. Erratum "Interrupt update during Initialization Mode" does not apply to F-Step, see chapter 9.1.

- 85/85 14.09.2010 BOSCH Robert Bosch GmbH 2009. All rights reserved, also regarding any disposal, exploitation, reproduction, editing, distribution, as well as in the event of applications for industrial property rights.

You might also like