RTEMS 6.1-rc2
Loading...
Searching...
No Matches
flashdev.h
Go to the documentation of this file.
1/* SPDX-License-Identifier: BSD-2-Clause */
2
11/*
12 * Copyright (C) 2023 Aaron Nyholm
13 *
14 * Redistribution and use in source and binary forms, with or without
15 * modification, are permitted provided that the following conditions
16 * are met:
17 * 1. Redistributions of source code must retain the above copyright
18 * notice, this list of conditions and the following disclaimer.
19 * 2. Redistributions in binary form must reproduce the above copyright
20 * notice, this list of conditions and the following disclaimer in the
21 * documentation and/or other materials provided with the distribution.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
24 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
27 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
28 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
29 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
30 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
31 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
32 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33 * POSSIBILITY OF SUCH DAMAGE.
34 */
35
36#ifndef _DEV_FLASHDEV_H
37#define _DEV_FLASHDEV_H
38
39#include <rtems/thread.h>
40#include <sys/types.h>
41
42#ifdef __cplusplus
43extern "C" {
44#endif
45
46
47typedef struct rtems_flashdev rtems_flashdev;
48
59/* IOCTL Calls */
60
66#define RTEMS_FLASHDEV_IOCTL_OBTAIN 0
72#define RTEMS_FLASHDEV_IOCTL_RELEASE 1
80#define RTEMS_FLASHDEV_IOCTL_JEDEC_ID 2
87#define RTEMS_FLASHDEV_IOCTL_ERASE 3
97#define RTEMS_FLASHDEV_IOCTL_REGION_SET 4
103#define RTEMS_FLASHDEV_IOCTL_REGION_UNSET 5
110#define RTEMS_FLASHDEV_IOCTL_TYPE 6
111
121#define RTEMS_FLASHDEV_IOCTL_PAGEINFO_BY_OFFSET 7
122
131#define RTEMS_FLASHDEV_IOCTL_PAGEINFO_BY_INDEX 8
132
138#define RTEMS_FLASHDEV_IOCTL_PAGE_COUNT 9
139
145#define RTEMS_FLASHDEV_IOCTL_WRITE_BLOCK_SIZE 10
146
151#define RTEMS_FLASHDEV_MAX_REGIONS 32
152
166
170typedef struct rtems_flashdev_region {
174 off_t offset;
178 size_t size;
180
189
195
200 uint32_t *bit_allocator;
202
210 off_t location;
211
218
234 int ( *read )(
235 rtems_flashdev *flash,
236 uintptr_t offset,
237 size_t count,
238 void *buffer
239 );
240
252 int ( *write )(
253 rtems_flashdev *flash,
254 uintptr_t offset,
255 size_t count,
256 const void *buffer
257 );
258
269 int ( *erase )(
270 rtems_flashdev *flash,
271 uintptr_t offset,
272 size_t count
273 );
274
282 uint32_t ( *jedec_id )(
283 rtems_flashdev *flash
284 );
285
295 int ( *flash_type )(
296 rtems_flashdev *flash,
298 );
299
314 rtems_flashdev *flash,
315 off_t search_offset,
316 off_t *page_offset,
317 size_t *page_size
318 );
319
333 rtems_flashdev *flashdev,
334 off_t search_index,
335 off_t *page_offset,
336 size_t *page_size
337 );
338
348 int ( *page_count )(
349 rtems_flashdev *flashdev,
350 int *page_count
351 );
352
363 rtems_flashdev *flashdev,
364 size_t *write_block_size
365 );
366
372 void ( *destroy )(
373 rtems_flashdev *flashdev
374 );
375
379 void *driver;
380
384 rtems_recursive_mutex mutex;
385
390};
391
404 size_t size
405);
406
422 rtems_flashdev *flash
423);
424
440 rtems_flashdev *flash,
441 const char *flash_path
442);
443
450 rtems_flashdev *flash
451);
452
459 rtems_flashdev *flash
460);
461
462#ifdef __cplusplus
463}
464#endif
465
468#endif /* _DEV_FLASHDEV_H */
rtems_flashdev * rtems_flashdev_alloc_and_init(size_t size)
Allocate and initialize the flash device.
Definition: flashdev.c:531
rtems_flashdev_flash_type
Enum for flash type returned from IOCTL call.
Definition: flashdev.h:156
int rtems_flashdev_register(rtems_flashdev *flash, const char *flash_path)
Register the flash device.
Definition: flashdev.c:460
void rtems_flashdev_destroy(rtems_flashdev *flash)
Destroys the flash device.
Definition: flashdev.c:508
int rtems_flashdev_init(rtems_flashdev *flash)
Initialize the flash device.
Definition: flashdev.c:524
void rtems_flashdev_destroy_and_free(rtems_flashdev *flash)
Destroys the flash device and frees its memory.
Definition: flashdev.c:513
@ RTEMS_FLASHDEV_NAND
The flash device is NAND flash.
Definition: flashdev.h:164
@ RTEMS_FLASHDEV_NOR
The flash device is NOR flash.
Definition: flashdev.h:160
Page information returned from IOCTL calls.
Definition: flashdev.h:206
off_t location
Offset or index to find page at.
Definition: flashdev.h:210
rtems_flashdev_region page_info
Information returned about the page. Including the base offset and size of page.
Definition: flashdev.h:216
Struct holding region definitions.
Definition: flashdev.h:184
int max_regions
The maximum regions that can be defined at once.
Definition: flashdev.h:188
rtems_flashdev_region * regions
Pointer to array of rtems_flashdev_region of length max_regions.
Definition: flashdev.h:194
uint32_t * bit_allocator
Array of uint32_t acting as bit allocator for regions array.
Definition: flashdev.h:200
General definition for on flash device.
Definition: flashdev.h:170
size_t size
Length of region.
Definition: flashdev.h:178
off_t offset
Base of region.
Definition: flashdev.h:174
Flash device.
Definition: flashdev.h:222
int(* erase)(rtems_flashdev *flash, uintptr_t offset, size_t count)
Call to the device driver to erase the flash device.
Definition: flashdev.h:269
int(* write_block_size)(rtems_flashdev *flashdev, size_t *write_block_size)
Call to device driver to return the minimum write size of the flash device.
Definition: flashdev.h:362
int(* page_info_by_offset)(rtems_flashdev *flash, off_t search_offset, off_t *page_offset, size_t *page_size)
Call to device driver to get size and offset of page at given offset.
Definition: flashdev.h:313
void * driver
Pointer to device driver.
Definition: flashdev.h:379
uint32_t(* jedec_id)(rtems_flashdev *flash)
Call to the device driver to return the JEDEC ID.
Definition: flashdev.h:282
int(* page_info_by_index)(rtems_flashdev *flashdev, off_t search_index, off_t *page_offset, size_t *page_size)
Call to device driver to get size and offset of page at given index.
Definition: flashdev.h:332
rtems_flashdev_region_table * region_table
Region table defining size and memory for region allocations.
Definition: flashdev.h:389
int(* write)(rtems_flashdev *flash, uintptr_t offset, size_t count, const void *buffer)
Call to the device driver to write to the flash device.
Definition: flashdev.h:252
int(* page_count)(rtems_flashdev *flashdev, int *page_count)
Call to device driver to return the number of pages on the flash device.
Definition: flashdev.h:348
void(* destroy)(rtems_flashdev *flashdev)
Destroys the flash device.
Definition: flashdev.h:372
int(* flash_type)(rtems_flashdev *flash, rtems_flashdev_flash_type *type)
Call to the device driver to return the flash type.
Definition: flashdev.h:295
int(* read)(rtems_flashdev *flash, uintptr_t offset, size_t count, void *buffer)
Call to the device driver to read the flash device.
Definition: flashdev.h:234
rtems_recursive_mutex mutex
Mutex to protect the flash device access.
Definition: flashdev.h:384
This header file provides the API of Self-Contained Objects.