RAZER CORE X CHROMA 에 ASRock BC-250 설치하기 2

RAZER CORE X CHROMA 의 썬더볼트 카드를 적출했다. 이걸 다시 사용할 날이 있을까 싶다. 이 PCB로 부터 디멘션 정보와 24핀 커넥터의 대략적인 위치만 알면 된다. 그래픽 카드가 장착되는 PCI-E 소켓 은 BC-250 장착에 방해가 됨으로 해당 소켓 부터 아래쪽은 필요가 없다. PCB 설계는 PSU 활성화 후 MCU 가 PSU로 부터 준비 완료 신호를 받으면 BC-250 의 전원 버튼을 트리거 하도록 설계 하려고 한다. EPS 8핀 은 필요 없어서 사용하지 않는다. USB-C 는 어떻게 할까 고민하다가 MCU 를 연결해주었다. 온도 센서도 추가할 것이기 때문에 시리얼로 동작 상태나 온도 정보 같은 걸 출력해볼 수 있다. 아래는 현재 설계 중인 회로도 이다. 혹시나 뭔가 건지러 오신 분들은 아직 검증된 회로는 아니라 저해상도로 올리니 이해 바란다. MCU는 CH32V003 시리즈를 사용했다. 기존에 장착된 LED 스트립은 그대로 쓸 수 있으면 쓰겠는데 과연 쓸 수 있을지는 모르겠다. 잘 안되면 그냥 사용해 본 걸로 바꾸는 방향이 빠를 거 같다. 앞으로 두번 정도는 더 수정을 해야 할 수도 있지만 일단은 기존 PCB 대신 장착될 PSU 컨트롤 보드이다. 딱히 특별한 기능도 없고, 나 혼자 쓸 물건이라 별 이상 없으면 그대로 사용할 것이다. PCB 디멘션은 나름 신경써서 측정했으니 조립은 어떻게든 될거라고 생각한다. ROG 폰트는 역시 멋지다. 다가오는 주말에는 USB 허브 쪽 설계를 하게 될 것 같다.

Radxa Zero 3W GPIO 제어하기


Radxa Zero 3W 모델이다. 나온지 좀 된 모델이고 RK3566은 에뮬레이터 게임기에도 많이 사용되고 있는 칩이다. 가격은 RaspberryPi Zero 2W 랑 가격 차이는 별로 안나지만 성능은 확실히 차이가 있다.

1. 동작 클럭이 더 높다. 그러나 발열도 더 느껴진다

2. LPDDR4 를 지원하여, LPDDR2 보다 더 빠른 전송 속도와 넓은 대역폭 그리고 저전력으로 동작한다. 

3. eMMC 추가 옵션

4. 외부 안테나 지원 (오버레이로 내장 외장 안테나 선택 가능 [sudo rsetup] )

5. 더 좋은 네트워크 및 무선 연결 

6. RaspberryPi 와 동일한 레이아웃의 GPIO 헤더, 전원 및 그라운드의 위치 동일

7. 기본적으로 핀들이 I2C, UART, SPI 등의 기능에 할당되어있다.
    사용하려면 디바이스 트리구조를 수정해야 한다.

8. GPIO 제어를 위해 libgpiod 를 사용하지만 gpiochip* 넘버와 line* 넘버를 설정하여 코드를 작성해야한다.
    이런 점은 RaspberryPi 의 RPi.GPIO 보다 다소 귀찮다고 할수 있다.

9. USB C 타입 사용


이런 점들을 보면 RaspberryPi Zero 2W 와 비교해보면 성능에 비해 가격이 저렴하게 느껴진다.

하지만 운용면에서는 다소 불편 할수도 있다.


Radxa Zero 3W는 GPIO 를 제어하려면 libgpiod 를 사용해야한다.

먼저 아래 명령어를 입력해서 라이브러리를 설치한다.


sudo apt update
sudo apt install libgpiod-dev

문서에 보면 각 핀 정보를 알아 볼 수 있다.

만일 본인이 핀을 설정하여 프로그램을 작성하였으나 의도대로 동작하지 않는다면 이미 해당 핀이 다른기능으로 설정이 되어있거나 사용중인 것일수도 있다.

다음 사용할 핀들을 알아보기 위해 아래 명령어를 입력한다.

gpioinfo gpiochip3

line 뒤에오는 숫자가 라인 넘버이고 PIN_*  이런식으로 이름이 붙은 것은 실체 핀의 넘버와 일치한다.

RaspberryPi 처럼 깔끔하게 정리되어있지는 않고 이렇게 각 gpiochip* 에 여기저기 퍼져있다.

어떻게 운용 할지는 본인의 선택이다.


다음은 PIN 11, 13, 12, 15 에 연결된 릴레이를 제어하는 간단한 c 예제이다.

어떤 보드가 되었건 기본은 켜고 끄는것 부터 시작이다.

#include <gpiod.h>
#include <stdio.h>
#include <unistd.h>

// 상수 정의
#define CHIP_NAME "gpiochip3" // 사용할 GPIO 칩 이름
#define INTERVAL 100000 // 간격 (마이크로초)

// 사용할 GPIO 라인 번호
int gpio_lines[] = {1, 2, 3, 8}; // 핀 헤더 11, 13, 12, 15 에 해당
int num_lines = sizeof(gpio_lines) / sizeof(gpio_lines[0]);

// 함수 선언
struct gpiod_chip* initialize_chip(const char *chipname);
int initialize_lines(struct gpiod_chip *chip, struct gpiod_line *lines[], int *gpio_lines, int num_lines);
void control_gpio(struct gpiod_line *lines[], int *gpio_lines, int num_lines, int interval);
void release_resources(struct gpiod_chip *chip, struct gpiod_line *lines[], int num_lines);

int main() {
struct gpiod_chip *chip;
struct gpiod_line *lines[4]; // 최대 4개의 GPIO 라인 관리

// GPIO 칩 초기화
chip = initialize_chip(CHIP_NAME);
if (!chip) return 1;

// GPIO 라인 초기화
if (initialize_lines(chip, lines, gpio_lines, num_lines) < 0) {
gpiod_chip_close(chip);
return 1;
}

// GPIO 제어
control_gpio(lines, gpio_lines, num_lines, INTERVAL);

// 리소스 해제
release_resources(chip, lines, num_lines);

return 0;
}

// GPIO 칩 초기화 함수
struct gpiod_chip* initialize_chip(const char *chipname) {
struct gpiod_chip *chip = gpiod_chip_open_by_name(chipname);
if (!chip) {
perror("gpiod_chip_open");
}
return chip;
}

// GPIO 라인 초기화 함수
int initialize_lines(struct gpiod_chip *chip, struct gpiod_line *lines[], int *gpio_lines, int num_lines) {
for (int i = 0; i < num_lines; i++) {
lines[i] = gpiod_chip_get_line(chip, gpio_lines[i]);
if (!lines[i]) {
perror("gpiod_chip_get_line");
return -1;
}

// GPIO를 출력으로 요청
if (gpiod_line_request_output(lines[i], "gpio_control", 0) < 0) {
perror("gpiod_line_request_output");
return -1;
}
}
return 0;
}

// GPIO 제어 함수
void control_gpio(struct gpiod_line *lines[], int *gpio_lines, int num_lines, int interval) {
for (int i = 0; i < num_lines; i++) {
gpiod_line_set_value(lines[i], 1); // GPIO On
printf("GPIO C3-L%d: ON\n", gpio_lines[i]);
usleep(interval);
gpiod_line_set_value(lines[i], 0); // GPIO Off
printf("GPIO C3-L%d: OFF\n", gpio_lines[i]);
usleep(interval);
}
}

// 리소스 해제 함수
void release_resources(struct gpiod_chip *chip, struct gpiod_line *lines[], int num_lines) {
for (int i = 0; i < num_lines; i++) {
gpiod_line_release(lines[i]);
}
gpiod_chip_close(chip);
}


아래 명령어를 사용해서 컴파일하고 실행한다.


gcc gpio_test.c -o gpio_test -lgpiod sudo ./gpio_test

다음과 영상과 같이 릴레이가 동작한다면 성공이다.






Comments

Popular posts from this blog

[POE] - 패스 오브 엑자일 획득키 F 의 사용법 (Path of Exile)

[AD보드] - 맥북 패널을 모니터로 만들기 ( LP154WP4-TLA1 )

[Arduino] - HC-06를 이용해 PC 와 Arduino 블루투스 연결