{"id":1502,"date":"2023-04-26T11:30:30","date_gmt":"2023-04-26T02:30:30","guid":{"rendered":"https:\/\/twarelab.com\/?p=1502"},"modified":"2023-04-26T11:30:30","modified_gmt":"2023-04-26T02:30:30","slug":"stm32f4-stm32f4-cpp-library-%ec%86%8c%ea%b0%9c","status":"publish","type":"post","link":"https:\/\/twarelab.com\/en\/blog\/stm32f4-stm32f4-cpp-library-%ec%86%8c%ea%b0%9c\/","title":{"rendered":"[STM32F4] STM32F4 CPP Library \uc18c\uac1c"},"content":{"rendered":"<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-large is-resized\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/twarelab.com\/wp-content\/uploads\/2023\/04\/DSC_1282-914x1024.png\" alt=\"\" class=\"wp-image-1505\" width=\"457\" height=\"512\" srcset=\"https:\/\/twarelab.com\/wp-content\/uploads\/2023\/04\/DSC_1282-914x1024.png 914w, https:\/\/twarelab.com\/wp-content\/uploads\/2023\/04\/DSC_1282-scaled-600x672.png 600w, https:\/\/twarelab.com\/wp-content\/uploads\/2023\/04\/DSC_1282-268x300.png 268w, https:\/\/twarelab.com\/wp-content\/uploads\/2023\/04\/DSC_1282-768x860.png 768w, https:\/\/twarelab.com\/wp-content\/uploads\/2023\/04\/DSC_1282-1371x1536.png 1371w, https:\/\/twarelab.com\/wp-content\/uploads\/2023\/04\/DSC_1282-1829x2048.png 1829w, https:\/\/twarelab.com\/wp-content\/uploads\/2023\/04\/DSC_1282-11x12.png 11w\" sizes=\"auto, (max-width: 457px) 100vw, 457px\" \/><\/figure>\n<\/div>\n\n\n<h2 class=\"wp-block-heading\">\uba38\ub9ac\ub9d0<\/h2>\n\n\n\n<p>\ub9ce\uc740 \uc784\ubca0\ub514\ub4dc \uc2dc\uc2a4\ud15c \uac1c\ubc1c\uc790\ub4e4\uc5d0\uac8c \uce5c\uc219\ud55c MCU\ub294 STMicro\uc758 STM32 \uc2dc\ub9ac\uc988\ub77c\uace0 \ud560 \uc218 \uc788\ub2e4. ARM Cortex Core\ub97c \uc0ac\uc6a9\ud558\uace0 \ub2e4\uc591\ud55c Peripheral\uc774 \uc548\uc815\uc801\uc774\ub77c\ub294 \uc810\uc774 \uc911\uc694\ud55c \uc774\uc720\uc774\uaca0\uc9c0\ub9cc \ubb34\ub8cc\ub85c \uc0ac\uc6a9\ud560 \uc218 \uc788\ub294 IDE \ud234\uacfc Flash \ub2e4\uc6b4\ub85c\ub4dc \ud234 \ub4f1 \uac1c\ubc1c\ud658\uacbd \uad6c\ucd95\uc5d0 \ube44\uc6a9\uc774 \ub4e4\uc9c0 \uc54a\ub294\ub2e4\ub294 \uc810\ub3c4 \uc0ac\uc6a9\uc790\uc758 \uc120\ud0dd\uc744 \ubc1b\ub294\ub370 \ub3c4\uc6c0\uc774 \ub418\uace0 \uc788\ub2e4.<\/p>\n\n\n\n<p>\ub610\ud55c \ub9ce\uc740 \uc0ac\uc6a9\uc790\ub4e4\uc774 \uc0ac\uc6a9\ud568\uc73c\ub85c\uc368 \ucc38\uc870\ud560\ub9cc\ud55c \uc608\uc81c\ub4e4\uc774 \ud48d\ubd80\ud558\uace0 \uc874\uc7ac\ud558\uace0 \uc788\uace0 \uc628\ub77c\uc778\uc5d0\uc11c \ucc38\uc870\ud560\ub9cc\ud55c \ud29c\ud1a0\ub9ac\uc5bc\uc774\ub098 \ube14\ub85c\uadf8\ub4e4\uc774 \uc874\uc7ac\ud55c\ub2e4\ub294 \uac83\ub3c4 ST MCU\ub97c \uc120\ud0dd\ud558\ub294 \uc774\uc720\uc774\ub2e4.<\/p>\n\n\n\n<p>\ud558\uc9c0\ub9cc \uadf8\ub9cc\ud07c \ub9ce\uc740 \uc0ac\uc6a9\uc790\ub4e4\uc774 \ubbf8\uc138\ud55c \uc81c\uc5b4\ub97c \ud558\ub294\ub370 \uc5b4\ub824\uc6c0\uc744 \uacaa\uace0 \uc788\ub294 \uac83\ub3c4 \uc0ac\uc2e4\uc774\ub2e4.<\/p>\n\n\n\n<p>\uc774\ub7f0 \uc774\uc720\ub85c \ud2f0\uc6e8\uc5b4\ub7a9\uc5d0\uc11c\ub294 \ub0b4\ubd80 \uac1c\ubc1c\uacfc\uc815\uc5d0\uc11c \uacbd\ud5d8\ud55c \ub0b4\uc6a9\uc744 \ud1a0\ub300\ub85c \uc7ac\uc0ac\uc6a9 \uac00\ub2a5\ud55c \uae30\ub2a5\ub4e4\uc744 \ub77c\uc774\ube0c\ub7ec\ub9ac\ud654\ud558\uc5ec \ub2e4\uc74c \uac1c\ubc1c \ud504\ub85c\uc81d\ud2b8\uc5d0\uc11c \uc5b4\ub824\uc6c0\uc744 \ubc18\ubcf5\ud558\uc9c0 \uc54a\uace0 \uac1c\ubc1c\uae30\uac04\uc744 \ub2e8\ucd95\ud560 \uc218 \uc788\ub3c4\ub85d \ud558\uc600\uace0, \uc774 \uacfc\uc815\uc5d0\uc11c \uac1c\ubc1c\ub41c STM32F4\uc6a9 \ub77c\uc774\ube0c\ub7ec\ub9ac\uc778 libtwlab_stm32f4.a \ub97c \uacf5\uc720\ud574\uc11c STM32F4\ub97c \uc0ac\uc6a9\ud558\uace0\uc790 \ud558\ub294 \uac1c\ubc1c\uc790\ub4e4\uc5d0\uac8c \ub3c4\uc6c0\uc774 \ub418\uace0\uc790 \ud55c\ub2e4.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\uae30\ubcf8 \uad6c\uc131<\/h2>\n\n\n\n<p>libtwlab_stm32f4.a\uac00 \ub300\uc0c1\uc73c\ub85c \ud558\ub294 MCU\ub294 STM32F4 \uacc4\uc5f4\uc774\ub2e4.<\/p>\n\n\n\n<p>\uae30\ubcf8 \uad6c\uc870\ub294 CPP\ub85c \ub418\uc5b4 \uc788\ub294\ub370, C\uac00 \uc544\ub2c8\ub77c CPP\ub85c \uad6c\uc131\ud55c \uc774\uc720\ub294 \uae30\ubcf8 Class\ub85c \ucd5c\uc18c\ud55c\uc758 \uac83\uc744 \uad6c\uc131\ud558\uc5ec \uac80\uc99d\ud558\uace0 \ud544\uc694\uc5d0 \ub530\ub77c\uc11c \ud574\ub2f9 Class\ub97c \uc0c1\uc18d\ubc1b\uc544\uc11c \ud655\uc7a5\ud574\uc11c \uc0ac\uc6a9\ud558\uae30 \uc704\ud55c \uac83\uc774\uba70, \uace0\uac1d\uc758 \ud544\uc694\uc5d0 \ub530\ub77c\uc11c \ub3d9\uc77c\ud55c \ud568\uc218\uba85\uc744 \uc0ac\uc6a9\ud558\uba74\uc11c\ub3c4 \ud30c\ub77c\ubbf8\ud130\ub97c \ub2ec\ub9ac \ud558\ub294 \ub370 CPP\uc758 \uc624\ubc84\ub85c\ub529 \uae30\ub2a5\uc774 \ud6a8\uacfc\uc801\uc774\uae30 \ub54c\ubb38\uc774\ub2e4.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\uc0ac\uc804 \uc900\ube44\ubb3c<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li>STMCubeIDE v1.11.0 \uc774\uc0c1<\/li>\n\n\n\n<li>STMCubeProgrammer v2.12.0 \uc774\uc0c1<\/li>\n\n\n\n<li>STlink or Nucleo Board(\ub2e4\uc6b4\ub85c\ub4dc\uc6a9)<\/li>\n\n\n\n<li>twareLAB\uc758 <a href=\"https:\/\/twarelab.com\/serial-to-ethernet-module\/\" target=\"_blank\" rel=\"noreferrer noopener\">TW100PC-EVB<\/a><\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">\ube14\ub85c\uadf8 \uc5f0\uc7ac \uad6c\uc131<\/h2>\n\n\n\n<ol class=\"wp-block-list\">\n<li>libtwlab_stm32f4.a \uad6c\uc131<\/li>\n\n\n\n<li>STMCubeIDE\uc5d0\uc11c CPP \ud504\ub85c\uc81d\ud2b8 \uc0dd\uc131<\/li>\n\n\n\n<li>STMCubeIDE\uc5d0 libtwlab_stm32f4.a \ub77c\uc774\ube0c\ub7ec\ub9ac \ucd94\uac00\ud558\uae30<\/li>\n\n\n\n<li>[\uc608\uc81c1] GPIO Blinking<\/li>\n\n\n\n<li>[\uc608\uc81c2] UART DMA \uc0ac\uc6a9\ud558\uc5ec Debug \uba54\uc2dc\uc9c0 \ucd9c\ub825\ud558\uae30<\/li>\n\n\n\n<li>[\uc608\uc81c3] Timer \uc124\uc815\ud558\uae30<\/li>\n\n\n\n<li>[\uc608\uc81c4] User Task \ubc0f User Timer \uc0dd\uc131\ud558\uae30<\/li>\n\n\n\n<li>[\uc608\uc81c5] \ub2e4\uc911 GPIO \uc81c\uc5b4 Task \ub9cc\ub4e4\uae30<\/li>\n\n\n\n<li>[\uc608\uc81c6] \ub2e4\uc911 ADC \uc81c\uc5b4 Task \ub9cc\ub4e4\uae30<\/li>\n\n\n\n<li>[\uc608\uc81c7] I2C\ub85c EEPROM \uc81c\uc5b4\ud558\uae30<\/li>\n\n\n\n<li>[\uc608\uc81c8] SPI DMA\ub97c \uc774\uc6a9\ud55c WIZnet W5500 \uc0ac\uc6a9\ud558\uae30<\/li>\n\n\n\n<li>[\uc608\uc81c9] AT Command \ucc98\ub9ac Task \ub9cc\ub4e4\uae30<\/li>\n\n\n\n<li>\uadf8\uc678<\/li>\n<\/ol>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\uba38\ub9ac\ub9d0 \ub9ce\uc740 \uc784\ubca0\ub514\ub4dc \uc2dc\uc2a4\ud15c \uac1c\ubc1c\uc790\ub4e4\uc5d0\uac8c \uce5c\uc219\ud55c MCU\ub294 STMicro\uc758 STM32 \uc2dc\ub9ac\uc988\ub77c\uace0 \ud560 \uc218 \uc788\ub2e4. ARM Cortex Core\ub97c \uc0ac\uc6a9\ud558\uace0 \ub2e4\uc591\ud55c Peripheral\uc774 \uc548\uc815\uc801\uc774\ub77c\ub294 \uc810\uc774 \uc911\uc694\ud55c \uc774\uc720\uc774\uaca0\uc9c0\ub9cc \ubb34\ub8cc\ub85c \uc0ac\uc6a9\ud560 \uc218 \uc788\ub294 IDE \ud234\uacfc Flash \ub2e4\uc6b4\ub85c\ub4dc \ud234 \ub4f1 \uac1c\ubc1c\ud658\uacbd \uad6c\ucd95\uc5d0 \ube44\uc6a9\uc774 \ub4e4\uc9c0 \uc54a\ub294\ub2e4\ub294 \uc810\ub3c4 \uc0ac\uc6a9\uc790\uc758 \uc120\ud0dd\uc744 \ubc1b\ub294\ub370 \ub3c4\uc6c0\uc774 \ub418\uace0 \uc788\ub2e4. \ub610\ud55c \ub9ce\uc740 \uc0ac\uc6a9\uc790\ub4e4\uc774 \uc0ac\uc6a9\ud568\uc73c\ub85c\uc368 \ucc38\uc870\ud560\ub9cc\ud55c [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":1505,"comment_status":"open","ping_status":"open","sticky":true,"template":"","format":"standard","meta":{"_themeisle_gutenberg_block_has_review":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[1,12],"tags":[43,45,44,42,32],"class_list":["post-1502","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-blog","category-ko","tag-cpp","tag-library","tag-ll_driver","tag-stm32f4","tag-tw100pc"],"jetpack_featured_media_url":"https:\/\/twarelab.com\/wp-content\/uploads\/2023\/04\/DSC_1282-scaled.png","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/posts\/1502","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/comments?post=1502"}],"version-history":[{"count":2,"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/posts\/1502\/revisions"}],"predecessor-version":[{"id":1506,"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/posts\/1502\/revisions\/1506"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/media\/1505"}],"wp:attachment":[{"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/media?parent=1502"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/categories?post=1502"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/twarelab.com\/en\/wp-json\/wp\/v2\/tags?post=1502"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}