Vehicle security

CAN Network

xoheon 2024. 6. 23. 22:07

CAN 이란 ?

CAN(Controller Area Netwokr), 차량 내에서 호스트 컴퓨터 없이 마이크로 컨트롤러나 장치들이 서로 통신하기 위해 설계된 표준 통신 규격이다,


챠량 내 ECU(Electronic Control Unit)들은 CAN 프로토콜을 사용하여 통신한다. 초기에는 차량 네트워크용으로 개발 되었으나 최근에는 차량뿐 아니라 산업 전분야에 폭넓게 적용되고있다.


CAN 등장 배경

초기 자동차에는 모듈이 많지 않았기에 UART방식, 일대일(Point-To-Point) 방식으로 ECU를 연결했다.

이러한 방식이라면 서로 다른 모듈간 통신을 위해서는 많은 선(Line)이 필요한 것이 문제 배선의 증가로 인한 유지보수 문제, 배선 증가로 무게 증가, 연비 하락과도 연결이 되었으며, 기술의 발전으로 차량 내부에 모듈 수가 점점 증가하고 있는 만큼 문제의 해결을 위해 CAN이 나왔다.

 

CAN은 여러 개의 CAN 디바이스가 서로 통신할 수 있는 안정적인 네트워크(다중 통신 방식 Multi Master 방식) 을 제공한다.네트워크의 장점은 ECU가 시스템 내 각 디바이스마다 아날로그 및 디지털 입력을 갖는 것이 아니라 단일의 CAN 인터페이스만 보유한다는점. 자동차의 전체적인 비용과 중량도 줄일 수 있다.


 

CAN 특징

1. 메시지 지향성 프로토콜(Message-Oriented Protocol)즉, 임의의 한 노드 A가 메시지를 전송했다면, A를 제외한 나머지 노드들은 A가 전송한 메시지가 자신에게 필요한 메시지인지를 판단(ID기반 판단)한다.

2. 자신에게 필요하다면 받아들이고, 아니라면 무시

3. CAN은 노드의 주소에 의해 데이터가 교환되는 것이 아니라 메시지의 우선순위에 따라 ID(IDentifier)를 할당하고,
이 ID를 이용해 메시지를 구별하는 방식을 사용합니다


4. 보완적인 에러 감지 매커니즘

5. CAN은 다양한 에러 감지 메커니즘이 상호 보완적으로 에러를 감지하기 때문에 높은 안전성 보장. 또한 메시지 전송 시, 에러가 감지되면 자동적으로 해당 메시지를 즉시 재전송하는 기능이 있기 때문에 다른 프로토콜에 비해 에러
회복 시간이 짧다.

6. 멀티 마스터 능력모든 노드가 버스 마스터가 되어 버스가 비어 있을 떄 (idle)라면 언제든지 메시지 전송이 가능
우선순위가 높은 메시지(이떄, 더 낮은 ID 번호가 더 높은 우선순위를 가짐)가 먼저 전송된다.

7. 모든 노드는 버스가 비워지는 즉시 메시지 전송을 시작, 만약 CAN 버스가 두 개의 노드에서 메시지를 동시에
전송하려고 하더라도, 우선순위(식별자, ID)에 따라 각각 전송이 된다.

8. CAN을 기반으로 한 네트워크에는 버스를 점유하기 위한 감독자 노드 (Bus Master)의 필요 없다.

9. 결점 있는 노드의 감지와 비활성화

10. CAN은 버스의 상태를 항상 모니터링하기 때문에 실시간으로 결함이 있는 노드를 감지해 해당 노드를 비활성화함으로네트워크의 신뢰성을 보장한다.

11. 전기적 노이즈에 강함

12. 꼬인 2선(Twist Pair Wire, CAN_H, CAN_L)을 이용해 전기적으로 차별되는 통신을 하여 전기적 노이즈에 매우 강함.

13. 저렴한 가격 및 구성의 용이성

14. 수십 개의 반도체 제조업체가 다양한 CAN 컨트롤러와 트랜시버를 개발 및 판매하고 있어 가격이 저렴하고 조달이 용이하다.


CAN BUS 네트워크 동작원리

CAN은 다중 통신망(Multi Master Network)이며 CSMA/CD+AMP(Carrier Sense Multiple Access/Collision Detection With Arbitration on Message Priority) 방식을 이용한다. CAN 노드에 메시지를 보내기 전에 CAN 버스라인이 사요중인지 파악한다. 또한 메시지 간 충돌 검출을 수행. 이때 어떠한 노드로부터 보내진 메시지는 송신측이나 수진측의 주소를 포함하지 않는다.

주소지정방식으로 통신하지않는다. 메시지의 처음부분에 CAN 네트워크상에서 각각의 노드를 식별할 수 있도록 각 노드마다 유일한 식별자(ID-11bits & 29bits)를 가지고 있다.

네트워크상에 연결된 모든 노드는 네트워크상에 있는 메시지를 수신한 후 자신이 필요로 하는 식별자의 메시지인 경우에만 받아들이고, 그렇지 않은 경우의 메시지는 무시한다.우선순위가 높은 메시지가 CAN 버스의 사용 권한을 보장받으며 이때 낮은 순위의 메시지는 자동적으로 다음 버스 사이클에 재전송이 되도록 한다.

각 CAN 메시지는 11비트의 식별자 (CAN 2.0A), 또는 29비트의 식별자 (CAN 2.0B)를 가지며, CAN의 맨 처음 시작 부분에 위치한다.

이러한 식별자는 메시지의 형태를 식별시켜주는 역할과 메시지에 우선순위를 부여하는 역할이다.

네트워크상 (CAN 통신 라인)에 흘러 다니는 여러 노드의 데이터들이 동시에 사용자가 필요로 하는 노드로 유입되는 경우에는 식별자의 숫자로 비교하여 먼저 받아들일 메시지의 우선 순위를 정하는데, 식별자의 숫자가 낮을수록 우선순위가 높다


CAN 메시지 포맷(구조)

CAN에서 데이터 프레임(Data Frame), 리모트 프레임(Remote Frame), 에러 프레임(Error Frame), 오버로드 프레임(Overload Frame)의 4가지 프레임 타입을 정의한다.

 

- 데이터 프레임 : 일반적으로 데이터 전송에 사용

 

- 리모트 프레임 : 수신할 노드에서 원하는 메시지를 전송할 수 있는 송신 노드에게 전송을 요청할때 사용

 

- 에러 프레임 : 메시지의 에러가 감지되었을 떄 시스템에 알릴 목적으로 사용

 

- 오버로드 프레임 : 메시지의 동기화를 목적으로 사용

 

CAN 통신에서 데이터 송수신은 메세지 프레임을 사용하여 이루어진다.

필드 설명
SOF(Start Or Frame) 한 개의 Dominant 비트로 구성되어 있으며, 메시지의 처음을 지시하고 모든 노드의
동기화를 위해 사용
Arbitration Field (중재 필드) 11비트 & 29비트 크기를 갖는 ID와 1티의 RTR(Remote Transmission Request)비트로 구성 이 영역은 둘 이상의 노드에서 메시지의 전송이 동시에 일어날 경우 발생하는 메시지 간의 충돌을 조정하는데 사용.


RTR 비트의 값은 데이터프레임인지('d') 리모트 프레임인지('r')를 결정하는데 사용
Control Field (제어 필드) 2비트의 IDE(iDentifier Extension) 비트, 4비트의 데이터 길이 코드(DLC, Data Length Code)로 구성. R0은 Reserved비트 (Extended 2.0B R0, R1)
Data Field (데이터 필드) 8Bytes까지 사용 가능하며, 데이터를 저장하는 데 사용된다.
(특정한 노드에서 다른 노드로 전송하는 데이터 포함)
CRC (Cyclic Redundancy Check) 필드 SOF에서부터 데이터 필드까지의 비트열을 이용해 생성한 15비트의 CRC 시퀀스와 하나의 'r'비트의 CRC 델리미터로 구성되어 있다. 메시지 상의 에러 유무를 검사하는데 사용
ACK (ACKnowledge) 필드 한 비트의 ACK 슬롯과 하나의 ACK 델리미터("d")로 구성되어 있다. 임의의 노드에서 올바른 메시지를 수신하게 되면 ACK 필드를 받는 순간 ACK 슬롯의 값을 'd'로 설정해 버스 상에서 계속 전송하게 된다.
EOF (End Of Frame, 프레임 종료) 7개의 'r'비트로 구성되어 메시지의 끝을 알리는 목적으로 사용

용어 설명

1. ECU(Electronic Control Unit)

 

- AirBag Control Unit (ACU)

- Engine Control Unit (ECU)

- Tansmission Control Unit (TCU)

- Brake Control Unit (BCU)

- On-Broard-Diagnostics(OBD)

ECU는 각종 센서에서 오는 정보를 토대로 최적의 결과를 판단하는 일을 한다. 자동차의 성능이 점점 발전함에 따라 구동계 뿐만 아니라 각종 전자장치를 제어하는 역할까지 한다.

2. 과거에는 ECU가 30개 미만으로 내장되 어 있었지만, 최근에는 편의를 위한 장치들이 많아지면서 최대 100여개까지도 내장.

3. ECU는 자동차에서 사용되는 많은 전자 제어 장치들을 지칭하는 단어.

4. CAN Controller, CAN Transceiver

 

CAN Controller : 내부 버퍼를 가지며 Transceiver에서 전달되는 수신 메시지에 대해 유효한 데이터인지 아닌지를 ID기반으로 판별한 후 유효한 데이터인 경우 MCU로 전달한다. 송신자의 메시지의 경우 MCU에서 전송하고자
하는 데이터에 대해 CAN Transceiver로 전달한다.

CAN Transceiver : CAN 버스 혹은 MCU에서 전달되는 송수신 데이터를 전기적 신호로 변환. CAN Transceiver은 MCU로부터 전달된 데이터를 CAN 통신용 데이터로 변환하며, CAN 버스에서 전달된 CAN 통신용 데이터를 MCU 송수신용 데이터로 변환한다.

 

5. 차량용 네트워크의 백본망을 구성하고 있는 CAN프로토콜은 CAN Controller와 CAN Transceiver로 구현된다.

6. CAN_H, CAN_L이때 꼬인 2선을 각각 CAN_H(or CAN High) & CAN_L(CAN Low)라 한다.

7. 전기적으로 신호를 전송하는 역항을 하는 물리계층에서, CAN은 광섬유나 꼬인 2선 (Twist Pair Wire)과 같은 다양한 종류의 매체를 사용하여 통신할 수 있다. 꼬인 2선 시그널링은 각 전선에 서로 다른 전압을 사용하여 버스 상에서의 
노이즈를 줄인다.


정리

1. 배선의 증가로 인한 여러 문제점을 해결하기 위해 CAN 등장

2. 하나의 CAN BUS 네트워크에 여러 ECU들이 연결되어 있음

3. CAN BUS 네트워크를 통해 각 노드 (ECU)들은 서로 메시지를 주고 받음

4. 메시지의 우선순위에 따라 할당된 유일한 식별자(ID)를 이용해 메시지를 구별함

5. CAN BUS 네트워크에 두 개의 노드에서 메시지가 동시에 전송되려고 할 떄, 더 높은 우선순위 (더 낮은 ID 번호)를 가진 노드의 메시지가 먼저 전송됨. 


참고

https://www.fescaro.com/kr/insight/blog.php#content

 

'Vehicle security' 카테고리의 다른 글

자율주행차 책임론  (1) 2024.06.23
V2X 통신/보안 표준  (0) 2024.06.23
FlexRay  (1) 2024.06.23
V2X  (0) 2024.06.23
LIN Network  (0) 2024.06.23