Busan IT/로봇제어2015. 10. 20. 09:13

==================================Outline====================================

교재 훑어보기

라즈베리파이2와 파이선을 활용한 코딩

----------------------------------------------------------------------------

 

교재 훑어보기

 

라즈베리 파이로 구현하는 사물 인터넷 프로젝트

 

Chapter 1 ~ 4

 

 

USART를 지원한다는 것은 비동기 데이터 전송 시 사용되는 헤더(header)와 테일(tail)을 만들어 준다는 뜻이다.

 

GPIO로 모든 신호를 만들어 낼 수 있다.


라즈베리파이2와 파이선을 활용한 코딩

 

라즈베리파이와 파이썬을 활용하여 코딩을 해보자.

 

1. 라즈베리파이2GPIO도면 습득

 

2. 파이선 라이브러리 설치

apt-get install python-dev

 

3. GPIO핀에 대해서 H/L pin 테스트

 

우선 파이선 패키지가 설치 되어 있는지 확인해 보자.

 

설치가 되어 있다면 파이썬 패키지를 설치해야 한다.

 

apt-get install python-dev

 

설치가 완료되면 'python'을 입력하여 프롬프트를 실행시키고 구구단을 프로그램을 만들어본다.

 

이제 LED를 활용하여 불을 켜고 끄는 프로그램을 만들어보자.



 

코드를 'led_onoff.py'로 저장한 후 ‘python led_onoff.py'로 실행시켜본다.

깜빡거리는 것을 볼 수 있다.

 


 

반응형
Posted by newind2000
Busan IT/ARM Controller2015. 10. 19. 13:48

==================================Outline====================================

Timer

----------------------------------------------------------------------------

 

reference manual p/372

 

타이머는 클럭의 설정의 따라 사용이 달라지게 된다.

 

//시간과 관련된 기능들은 모두 클럭의 영향을 받는다.

 

 


 

캡쳐/비교 채널은 쉐도우 레지스터를 가지고 있는다. 이것은 필요한 정보를 잠시 저장하는 레지스터이다.

 

 

타이머를 사용한 딜레이 함수를 만들어 보자.

 

함수 이름 : Delay_ms(uint8_t time)

 

ex) 8ms 지연 -> Delay_ms(8); 

 

1ms 간격의 Timer Interrupt 함수를 우선 만들어야 한다.

 

1ms Timer Interrupt 서비스 루틴 안에서 별도의 카운트가 필요하다.


코딩 순서는 다음과 같다.

- 클럭을 공급한다.

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);

RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);


- 타이머 설정을 해준다.(TIM2, NVIC)


void  TIM2_IRQHandler(void)

{

if(TIM_GetITStatus(TIM2,TIM_IT_Update) != RESET)

    {

// Timer Interrupt 가 처리하는 내용

//GPIOA->ODR ^= (uint32_t)0x01;

     

TIM_ClearITPendingBit(TIM2, TIM_IT_Update); // Clear the interrupt flag

++uiDelay;

    }

return;

}

void TIM2_init(void)

{

TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;

/* TIM2 Initialize */   

    TIM_TimeBaseStructure.TIM_Period = (1200-1); 

    TIM_TimeBaseStructure.TIM_Prescaler = (60-1); 

    TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;

    TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;

    TIM_TimeBaseInit(TIM2,&TIM_TimeBaseStructure);

}


void NVIC_init(void)

{

NVIC_InitTypeDef NVIC_InitStructure;

/* Enable TIM2 global interrupt with Preemption Priority 0 and Sub Priority as 2 */

NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;

NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;

NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;

NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;

NVIC_Init(&NVIC_InitStructure);

}

- 타이머 작동 확인을 위한 내부 LED설정을 해준다.

void PA0_out(void)

{

/* Configure all the GPIOA in Input Floating mode */

GPIO_InitTypeDef GPIO_InitStructure;

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;

GPIO_Init(GPIOA, &GPIO_InitStructure);

}




/*** 소스 ***/

#include <stm32f10x.h>

#define ON 0x01
#define OFF 0x00

unsigned int uiDelay;

void  TIM2_IRQHandler(void)
{
    
  if(TIM_GetITStatus(TIM2,TIM_IT_Update) != RESET)
    {
      // Timer Interrupt 가 처리하는 내용
      //GPIOA->ODR ^= (uint32_t)0x01;
                
      TIM_ClearITPendingBit(TIM2, TIM_IT_Update); // Clear the interrupt flag
      ++uiDelay;  
    }
    
    return;
}

void PA0_out(void)
{
  /* Configure all the GPIOA in Input Floating mode */
  GPIO_InitTypeDef GPIO_InitStructure;
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOA, &GPIO_InitStructure);
}

void TIM2_init(void)
{
  TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
  
  /* TIM2 Initialize */   
    TIM_TimeBaseStructure.TIM_Period = (1200-1); 
    TIM_TimeBaseStructure.TIM_Prescaler = (60-1); 
    TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
    TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
    TIM_TimeBaseInit(TIM2,&TIM_TimeBaseStructure);
}

void NVIC_init(void)
{
  NVIC_InitTypeDef NVIC_InitStructure;
  /* Enable TIM2 global interrupt with Preemption Priority 0 and Sub Priority as 2 */
  NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  NVIC_Init(&NVIC_InitStructure);
}
void Delay_ms(unsigned int uiNum)
{
  uiDelay = 0;
  while(uiNum > uiDelay) ;
}

int main(void)
{
  // 사용할 기능 : GPIOA0, TIM2
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
  PA0_out();
  TIM2_init();
  NVIC_init();
  
  TIM_Cmd(TIM2, ENABLE);    // Timer 활성화
  TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);  // Timer Interrupt 활성화
  
  while(1)
  {
    Delay_ms(1000);
    GPIOA->ODR ^= (uint32_t)0x01;
  }
}

 

반응형

'Busan IT > ARM Controller' 카테고리의 다른 글

USART를 활용한 LED ON/OFF  (0) 2015.10.30
Timer를 활용한 LED제어, LCD 제어  (0) 2015.10.20
Advanced-control timers(TIM1&8)  (0) 2015.10.16
인터럽트 코드 분석  (0) 2015.10.13
Interrupt  (0) 2015.10.12
Posted by newind2000
Busan IT/로봇제어2015. 10. 16. 16:07

==================================Outline==================================== 

모듈 파라미터

장치 드라이버의 형식

----------------------------------------------------------------------------

//모듈을 위한 프로그래밍 시 코딩 파일의 이름을 'main'으로하면 에러가 난다.

 

 

모듈 파라미터

 

make up, down도 마저 작성한 후 모듈을 올리고 내려 본다.

 

//모듈 상태를 보는 명령어 ‘lsmod'

 

 

 

모듈 사용 시 인자를 선언하여 그 값을 바꿔줄 수 있다.

 

이를 사용하기 위해서는 아래의 매크로를 등록해야 한다.

 

module_param(name, type, perm);

name => 변수 이름type   => 변수 타입perm  => 퍼미션

 

int iNum과 문자열 “Hello"를 선언해주고 모듈 인자에 넣어 값을 변동한 뒤 출력해본다.

 

insmod smart.ko iNum=999

insmod smart.ko cpT="Hello"

 

//‘dmesg’로 출력할 수 있다..

 



[smart.c]

#include <linux/init.h>
#include <linux/module.h>
#include <linux/kernel.h>

MODULE_LICENSE("GPL");

static int rp_init(void);
static void rp_exit(void);
module_init(rp_init);
module_exit(rp_exit);
int iNum = 100;
char * cpT = "Test Message";
module_param(iNum, int0);//charp = char *

static int rp_init(void)
{
  printk("Welcome to Smart World!\n");
  printk("[%d]\n", iNum);
  printk("[%s]\n", cpT);
  return 0;
}

static void rp_exit(void)
{
  printk("Farewell Dear\n");

  return;
}  

[makefile]

obj-m = smart.o

#KDIR = /lib/modules/$(shell uname -r)/build
KDIR = /usr/src/linux

PWD = $(shell pwd)

all:
  @clear
  $(MAKE) -C $(KDIR) M=$(PWD) modules
  @ls -al smart.ko

up:
  @clear
  @insmod smart.ko
  @echo ================== dmesg =================
  @dmesg | tail
  @echo ================== dmesg =================

down:
  @clear
  @rmmod smart
  @echo ================== dmesg =================
  @dmesg | tail
  @echo ================== dmesg =================

clean:
  @clear
  @rm -rf *.ko
  @rm -rf *.mod.*
  @rm -rf .*.cmd
  @rm -rf *.o
  @rm -rf modules.order
  @rm -rf Module.symvers
  @rm -rf .tmp_versions
  @ls -al
  @echo Clean :Done.

 

장치 드라이버의 형식

 

Unix방식을 물려받은 linux는 모든 장치들을 파일로 관리한다.

노란색 폴더가 장치를 의미한다.

 

장치 드라이버의 형식

 

장치 드라이버는 3개로 나눈다. 

 

c: c for character : 데이터 전송 단위 1byte(크기가 고정되어 있지 않다)

ex) 마우스, 키보드

 

b: b for block: 블록은 데이터 크기가 고정되어 있다. 데이터를 보낼 때 고정된 크기만큼 보낸다.

ex) 하드드라이브

 

n: n for network: ???

 

Q: 하드드라이브가 일정한 크기(블록으)로 조각나 있는 이유?

반응형
Posted by newind2000