RTC auf true
Diff: features/lwipstack/LWIPMemoryManager.h
- Revision:
- 0:38ceb79fef03
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/features/lwipstack/LWIPMemoryManager.h Wed Nov 28 15:10:15 2018 +0000 @@ -0,0 +1,200 @@ +/* Copyright (c) 2017 ARM Limited + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef LWIP_MEMORY_MANAGER_H +#define LWIP_MEMORY_MANAGER_H + +#include "EMACMemoryManager.h" + +class LWIPMemoryManager : public EMACMemoryManager { +public: + + /** + * Allocates memory buffer from the heap + * + * Memory buffer allocated from heap is always contiguous and can be arbitrary size. + * + * @param size Size of the memory to allocate in bytes + * @param align Memory alignment requirement in bytes + * @return Allocated memory buffer, or NULL in case of error + */ + virtual emac_mem_buf_t *alloc_heap(uint32_t size, uint32_t align); + + /** + * Allocates memory buffer chain from a pool + * + * Memory allocated from pool is contiguous if size is equal or less than + * (aligned) allocation unit, otherwise may be chained. Will typically come from + * fixed-size packet pool memory. + * + * @param size Total size of the memory to allocate in bytes + * @param align Memory alignment requirement for each buffer in bytes + * @return Allocated memory buffer chain, or NULL in case of error + */ + virtual emac_mem_buf_t *alloc_pool(uint32_t size, uint32_t align); + + /** + * Get memory buffer pool allocation unit + * + * Returns the maximum size of contiguous memory that can be allocated from a pool. + * + * @param align Memory alignment requirement in bytes + * @return Contiguous memory size + */ + virtual uint32_t get_pool_alloc_unit(uint32_t align) const; + + /** + * Free memory buffer chain + * + * If memory buffer is chained must point to the start of the chain. Frees all buffers + * from the chained list. + * + * @param buf Memory buffer chain to be freed. + */ + virtual void free(emac_mem_buf_t *buf); + + /** + * Return total length of a memory buffer chain + * + * Returns a total length of this buffer and any following buffers in the chain. + * + * @param buf Memory buffer chain + * @return Total length in bytes + */ + virtual uint32_t get_total_len(const emac_mem_buf_t *buf) const; + + /** + * Copy a memory buffer chain + * + * Copies data from one buffer chain to another. Copy operation does not adjust the lengths + * of the copied-to memory buffer chain, so chain total lengths must be the same. + * + * @param to_buf Memory buffer chain to copy to + * @param from_buf Memory buffer chain to copy from + */ + virtual void copy(emac_mem_buf_t *to_buf, const emac_mem_buf_t *from_buf); + + /** + * Copy to a memory buffer chain + * + * Copies data to a buffer chain. Copy operation does not adjust the lengths + * of the copied-to memory buffer chain, so chain total length must match the + * copied length. + * + * @param to_buf Memory buffer chain to copy to + * @param ptr Pointer to data + * @param len Data length + */ + virtual void copy_to_buf(emac_mem_buf_t *to_buf, const void *ptr, uint32_t len); + + /** + * Copy from a memory buffer chain + * + * Copies data from a memory buffer chain. + * + * @param len Data length + * @param ptr Pointer to data + * @param from_buf Memory buffer chain to copy from + * @return Length of the data that was copied + */ + virtual uint32_t copy_from_buf(void *ptr, uint32_t len, const emac_mem_buf_t *from_buf) const; + + /** + * Concatenate two memory buffer chains + * + * Concatenates buffer chain to end of the other buffer chain. Concatenated-to buffer total length + * is adjusted accordingly. cat_buf must point to the start of a the chain. After concatenation + * to_buf's chain now owns those buffers, and they will be freed when the to_buf chain is freed. + * + * @param to_buf Memory buffer chain to concatenate to + * @param cat_buf Memory buffer chain to concatenate + */ + virtual void cat(emac_mem_buf_t *to_buf, emac_mem_buf_t *cat_buf); + + /** + * Returns the next buffer + * + * Returns the next buffer from the memory buffer chain. + * + * @param buf Memory buffer + * @return The next memory buffer, or NULL if last + */ + virtual emac_mem_buf_t *get_next(const emac_mem_buf_t *buf) const; + + /** + * Return pointer to the payload of the buffer + * + * @param buf Memory buffer + * @return Pointer to the payload + */ + virtual void *get_ptr(const emac_mem_buf_t *buf) const; + + /** + * Return payload size of the buffer + * + * @param buf Memory buffer + * @return Size in bytes + */ + virtual uint32_t get_len(const emac_mem_buf_t *buf) const; + + /** + * Sets the payload size of the buffer + * + * The allocated payload size will not change. It is not permitted + * to change the length of a buffer that is not the first (or only) in a chain. + * + * @param buf Memory buffer + * @param len Payload size, must be less or equal allocated size + */ + virtual void set_len(emac_mem_buf_t *buf, uint32_t len); + +private: + + /** + * Returns a total memory alignment size + * + * Calculates the total memory alignment size for a memory buffer chain. + * Used internally on pool allocation. + * + * @param size Size of the memory to allocate in bytes + * @param align Memory alignment requirement for each buffer in bytes + * @return Total alignment needed in bytes + */ + uint32_t count_total_align(uint32_t size, uint32_t align); + + /** + * Aligns a memory buffer chain + * + * Aligns a memory buffer chain and updates lengths and total lengths + * accordingly. There needs to be enough overhead to do the alignment + * for all buffers. + * + * @param pbuf Memory buffer + * @param align Memory alignment requirement for each buffer in bytes + */ + void align_memory(struct pbuf *pbuf, uint32_t align); + + /** + * Sets total lengths of a memory buffer chain + * + * Sets total length fields for a memory buffer chain based on buffer + * length fields. All total lengths are calculated again. + * + * @param pbuf Memory buffer + */ + void set_total_len(struct pbuf *pbuf); +}; + +#endif /* LWIP_MEMORY_MANAGER_H */