mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
20003: coap: create typedef for CoAP methods r=benpicco a=benpicco 20028: nanocoap: fix incorrect uses of coap_get_code() r=benpicco a=benpicco 20036: boards/nucleo-l4r5zi : add PWM configuration r=benpicco a=krzysztof-cabaj ### Contribution description This PR adds to the Nucleo-l4r5zi PWM configuration ### Testing procedure Flash the board using `tests/periph/pwm` program. Check if you could, for example, change LED intensity using PWM. ### Issues/PRs references None. 20041: pkg/littlefs2: bump to v2.8.1 r=benpicco a=bergzand ### Contribution description Minor version number bump. ### Testing procedure - Check if I copied the correct commit hash. - Run the tests. ### Issues/PRs references None Co-authored-by: Benjamin Valentin <benjamin.valentin@ml-pa.com> Co-authored-by: krzysztof-cabaj <kcabaj@gmail.com> Co-authored-by: Koen Zandberg <koen@bergzand.net>
This commit is contained in:
commit
c0ae75b339
@ -18,6 +18,7 @@ config BOARD_NUCLEO_L4R5ZI
|
|||||||
select HAS_PERIPH_ADC
|
select HAS_PERIPH_ADC
|
||||||
select HAS_PERIPH_I2C
|
select HAS_PERIPH_I2C
|
||||||
select HAS_PERIPH_LPUART
|
select HAS_PERIPH_LPUART
|
||||||
|
select HAS_PERIPH_PWM
|
||||||
select HAS_PERIPH_RTC
|
select HAS_PERIPH_RTC
|
||||||
select HAS_PERIPH_RTT
|
select HAS_PERIPH_RTT
|
||||||
select HAS_PERIPH_SPI
|
select HAS_PERIPH_SPI
|
||||||
|
@ -5,6 +5,7 @@ CPU_MODEL = stm32l4r5zi
|
|||||||
FEATURES_PROVIDED += periph_adc
|
FEATURES_PROVIDED += periph_adc
|
||||||
FEATURES_PROVIDED += periph_i2c
|
FEATURES_PROVIDED += periph_i2c
|
||||||
FEATURES_PROVIDED += periph_lpuart
|
FEATURES_PROVIDED += periph_lpuart
|
||||||
|
FEATURES_PROVIDED += periph_pwm
|
||||||
FEATURES_PROVIDED += periph_rtc
|
FEATURES_PROVIDED += periph_rtc
|
||||||
FEATURES_PROVIDED += periph_rtt
|
FEATURES_PROVIDED += periph_rtt
|
||||||
FEATURES_PROVIDED += periph_spi
|
FEATURES_PROVIDED += periph_spi
|
||||||
|
@ -167,6 +167,50 @@ static const adc_conf_t adc_config[] = {
|
|||||||
|
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @name PWM configuration
|
||||||
|
*
|
||||||
|
* To find appriopate device and channel find in the MCU datasheet table
|
||||||
|
* concerning "Alternate function AF0 to AF7" a text similar to TIM[X]_CH[Y
|
||||||
|
],
|
||||||
|
* where:
|
||||||
|
* TIM[X] - is device,
|
||||||
|
* [Y] - describes used channel (indexed from 0), for example TIM2_CH1 is
|
||||||
|
* channel 0 in configuration structure (cc_chan - field),
|
||||||
|
* Port column in the table describes connected port.
|
||||||
|
*
|
||||||
|
* For Nucleo-L4R5ZI this information is in the datasheet, Table 16, page
|
||||||
|
* 117.
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
static const pwm_conf_t pwm_config[] = {
|
||||||
|
{
|
||||||
|
.dev = TIM2,
|
||||||
|
.rcc_mask = RCC_APB1ENR1_TIM2EN,
|
||||||
|
.chan = { { .pin = GPIO_PIN(PORT_A, 0) /* CN10 D32 */, .cc_chan = 0},
|
||||||
|
{ .pin = GPIO_PIN(PORT_A, 1) /* CN10 A8 */, .cc_chan = 1},
|
||||||
|
{ .pin = GPIO_PIN(PORT_A, 2) /* CN10 D26 */, .cc_chan = 2},
|
||||||
|
{ .pin = GPIO_PIN(PORT_A, 3) /* CN9 A0 */, .cc_chan = 3} },
|
||||||
|
.af = GPIO_AF1,
|
||||||
|
.bus = APB1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.dev = TIM3,
|
||||||
|
.rcc_mask = RCC_APB1ENR1_TIM3EN,
|
||||||
|
.chan = { { .pin = GPIO_PIN(PORT_B, 4) /* CN7 D25 */, .cc_chan = 0},
|
||||||
|
{ .pin = GPIO_PIN(PORT_E, 4) /* CN9 D57 */, .cc_chan = 1},
|
||||||
|
{ .pin = GPIO_PIN(PORT_B, 0) /* CN10 D33 */, .cc_chan = 2},
|
||||||
|
{ .pin = GPIO_PIN(PORT_B, 1) /* CN10 A6 */, .cc_chan = 3} },
|
||||||
|
.af = GPIO_AF2,
|
||||||
|
.bus = APB1
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
#define PWM_NUMOF ARRAY_SIZE(pwm_config)
|
||||||
|
|
||||||
|
/** @} */
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
PKG_NAME=littlefs2
|
PKG_NAME=littlefs2
|
||||||
PKG_URL=https://github.com/littlefs-project/littlefs.git
|
PKG_URL=https://github.com/littlefs-project/littlefs.git
|
||||||
# v2.8
|
# v2.8.1
|
||||||
PKG_VERSION=f77214d1f0a8ccd7ddc7e1204fedd25ee5a41534
|
PKG_VERSION=c733d9ec5776dfc949ec6dc71fa9ce3ff71de6e5
|
||||||
PKG_LICENSE=Apache-2.0
|
PKG_LICENSE=Apache-2.0
|
||||||
|
|
||||||
include $(RIOTBASE)/pkg/pkg.mk
|
include $(RIOTBASE)/pkg/pkg.mk
|
||||||
|
@ -163,14 +163,20 @@ extern "C" {
|
|||||||
* @name CoAP method codes used in header
|
* @name CoAP method codes used in header
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define COAP_CLASS_REQ (0)
|
#define COAP_CLASS_REQ (0) /**< Code Class for Request */
|
||||||
#define COAP_METHOD_GET (1)
|
|
||||||
#define COAP_METHOD_POST (2)
|
/**
|
||||||
#define COAP_METHOD_PUT (3)
|
* @brief CoAP method codes used in request
|
||||||
#define COAP_METHOD_DELETE (4)
|
*/
|
||||||
#define COAP_METHOD_FETCH (5)
|
typedef enum {
|
||||||
#define COAP_METHOD_PATCH (6)
|
COAP_METHOD_GET = 1, /**< GET request (no paylod) */
|
||||||
#define COAP_METHOD_IPATCH (7)
|
COAP_METHOD_POST = 2, /**< POST request (resource processes payload) */
|
||||||
|
COAP_METHOD_PUT = 3, /**< PUT request (update resource with payload) */
|
||||||
|
COAP_METHOD_DELETE = 4, /**< DELETE request (no payload, remove resource)*/
|
||||||
|
COAP_METHOD_FETCH = 5, /**< FETCH request (RFC 8132) */
|
||||||
|
COAP_METHOD_PATCH = 6, /**< PATCH request (RFC 8132) */
|
||||||
|
COAP_METHOD_IPATCH = 7, /**< iPATCH request (RFC 8132) */
|
||||||
|
} coap_method_t;
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -205,7 +205,7 @@ typedef struct {
|
|||||||
nanocoap_sock_t *sock; /**< socket used for the request */
|
nanocoap_sock_t *sock; /**< socket used for the request */
|
||||||
const char *path; /**< path on the server */
|
const char *path; /**< path on the server */
|
||||||
uint32_t blknum; /**< current block number */
|
uint32_t blknum; /**< current block number */
|
||||||
uint8_t method; /**< request method (GET, POST, PUT) */
|
coap_method_t method; /**< request method (GET, POST, PUT) */
|
||||||
uint8_t blksize; /**< CoAP blocksize exponent */
|
uint8_t blksize; /**< CoAP blocksize exponent */
|
||||||
} coap_block_request_t;
|
} coap_block_request_t;
|
||||||
|
|
||||||
@ -580,7 +580,7 @@ ssize_t nanocoap_request(coap_pkt_t *pkt, const sock_udp_ep_t *local,
|
|||||||
static inline int nanocoap_block_request_connect_url(coap_block_request_t *ctx,
|
static inline int nanocoap_block_request_connect_url(coap_block_request_t *ctx,
|
||||||
nanocoap_sock_t *sock,
|
nanocoap_sock_t *sock,
|
||||||
const char *url,
|
const char *url,
|
||||||
uint8_t method,
|
coap_method_t method,
|
||||||
coap_blksize_t blksize)
|
coap_blksize_t blksize)
|
||||||
{
|
{
|
||||||
ctx->sock = sock;
|
ctx->sock = sock;
|
||||||
|
@ -415,7 +415,7 @@ static ssize_t _delete_file(coap_pkt_t *pdu, uint8_t *buf, size_t len,
|
|||||||
static ssize_t gcoap_fileserver_file_handler(coap_pkt_t *pdu, uint8_t *buf, size_t len,
|
static ssize_t gcoap_fileserver_file_handler(coap_pkt_t *pdu, uint8_t *buf, size_t len,
|
||||||
struct requestdata *request)
|
struct requestdata *request)
|
||||||
{
|
{
|
||||||
switch (coap_get_code(pdu)) {
|
switch (coap_get_code_raw(pdu)) {
|
||||||
case COAP_METHOD_GET:
|
case COAP_METHOD_GET:
|
||||||
return _get_file(pdu, buf, len, request);
|
return _get_file(pdu, buf, len, request);
|
||||||
#if IS_USED(MODULE_GCOAP_FILESERVER_PUT)
|
#if IS_USED(MODULE_GCOAP_FILESERVER_PUT)
|
||||||
@ -549,7 +549,7 @@ static ssize_t gcoap_fileserver_directory_handler(coap_pkt_t *pdu, uint8_t *buf,
|
|||||||
struct requestdata *request,
|
struct requestdata *request,
|
||||||
const char *root, const char* resource_dir)
|
const char *root, const char* resource_dir)
|
||||||
{
|
{
|
||||||
switch (coap_get_code(pdu)) {
|
switch (coap_get_code_raw(pdu)) {
|
||||||
case COAP_METHOD_GET:
|
case COAP_METHOD_GET:
|
||||||
return _get_directory(pdu, buf, len, request, root, resource_dir);
|
return _get_directory(pdu, buf, len, request, root, resource_dir);
|
||||||
#if IS_USED(MODULE_GCOAP_FILESERVER_PUT)
|
#if IS_USED(MODULE_GCOAP_FILESERVER_PUT)
|
||||||
|
@ -1180,7 +1180,7 @@ static void _cache_process(gcoap_request_memo_t *memo,
|
|||||||
#if IS_USED(MODULE_NANOCOAP_CACHE)
|
#if IS_USED(MODULE_NANOCOAP_CACHE)
|
||||||
nanocoap_cache_entry_t *ce;
|
nanocoap_cache_entry_t *ce;
|
||||||
/* cache_key in memo is pre-processor guarded so we need to as well */
|
/* cache_key in memo is pre-processor guarded so we need to as well */
|
||||||
if ((ce = nanocoap_cache_process(memo->cache_key, coap_get_code(&req), pdu, pdu_len))) {
|
if ((ce = nanocoap_cache_process(memo->cache_key, coap_get_code_raw(&req), pdu, pdu_len))) {
|
||||||
ce->truncated = (memo->state == GCOAP_MEMO_RESP_TRUNC);
|
ce->truncated = (memo->state == GCOAP_MEMO_RESP_TRUNC);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
@ -1288,7 +1288,7 @@ static bool _cache_lookup(gcoap_request_memo_t *memo,
|
|||||||
_update_memo_cache_key(memo, cache_key);
|
_update_memo_cache_key(memo, cache_key);
|
||||||
/* cache hit, methods are equal, and cache entry is not stale */
|
/* cache hit, methods are equal, and cache entry is not stale */
|
||||||
if (*ce &&
|
if (*ce &&
|
||||||
((*ce)->request_method == coap_get_code(pdu)) &&
|
((*ce)->request_method == coap_get_code_raw(pdu)) &&
|
||||||
!nanocoap_cache_entry_is_stale(*ce, now)) {
|
!nanocoap_cache_entry_is_stale(*ce, now)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -305,7 +305,7 @@ nanocoap_cache_entry_t *nanocoap_cache_add_by_req(const coap_pkt_t *req,
|
|||||||
nanocoap_cache_key_generate(req, cache_key);
|
nanocoap_cache_key_generate(req, cache_key);
|
||||||
|
|
||||||
return nanocoap_cache_add_by_key(cache_key,
|
return nanocoap_cache_add_by_key(cache_key,
|
||||||
coap_get_code((coap_pkt_t *)req),
|
coap_get_code_raw((coap_pkt_t *)req),
|
||||||
resp,
|
resp,
|
||||||
resp_len);
|
resp_len);
|
||||||
}
|
}
|
||||||
|
@ -294,7 +294,7 @@ ssize_t nanocoap_sock_request_cb(nanocoap_sock_t *sock, coap_pkt_t *pkt,
|
|||||||
_send_ack(sock, pkt);
|
_send_ack(sock, pkt);
|
||||||
/* fall-through */
|
/* fall-through */
|
||||||
case COAP_TYPE_ACK:
|
case COAP_TYPE_ACK:
|
||||||
if (cb && coap_get_code(pkt) == COAP_CODE_EMPTY) {
|
if (cb && coap_get_code_raw(pkt) == COAP_CODE_EMPTY) {
|
||||||
/* empty ACK, wait for separate response */
|
/* empty ACK, wait for separate response */
|
||||||
state = STATE_RESPONSE_RCVD;
|
state = STATE_RESPONSE_RCVD;
|
||||||
deadline = _deadline_from_interval(CONFIG_COAP_SEPARATE_RESPONSE_TIMEOUT_MS
|
deadline = _deadline_from_interval(CONFIG_COAP_SEPARATE_RESPONSE_TIMEOUT_MS
|
||||||
|
Loading…
Reference in New Issue
Block a user