Revision tags: release/7.0.0_cvs, release/7.0.0, release/6.3.0_cvs, release/6.3.0 |
|
#
6634080b |
| 05-Jun-2007 |
Warner Losh <imp@FreeBSD.org> |
MFp4: When querying the operating condition of SD cards (using the application specific SEND_OP_COND (CMD55 + ACMD41), go ahead and allow 100 tries. This gives a timeout of a second rather than the
MFp4: When querying the operating condition of SD cards (using the application specific SEND_OP_COND (CMD55 + ACMD41), go ahead and allow 100 tries. This gives a timeout of a second rather than the ~100ms the old style produces.
I've had one old 16MB SD card which needs the extra time. I've now had reports from the field that other cards need this too.
Originally done at BSDcan 2007 while waiting to give my embedding madness minitalk.
show more ...
|
#
14eced72 |
| 26-May-2007 |
Warner Losh <imp@FreeBSD.org> |
A careful reading of the disclaimer that is required to download the SD Simplified specification, as well as other SD and SDIO implemenations I've examined, suggest this disclaimer may be required. I
A careful reading of the disclaimer that is required to download the SD Simplified specification, as well as other SD and SDIO implemenations I've examined, suggest this disclaimer may be required. It is unclear to me exactly what the license would be for, or why it might be required. Err on the side of caution and include this disclaimer so anybody deploying this code can judge for themselves. I have no further unformation about the details.
show more ...
|
#
0e1466ac |
| 15-May-2007 |
Warner Losh <imp@FreeBSD.org> |
First cut at making detach work. also add sdh as a possible mmc bridge.
Submitted by: Andrea Bittau (Andrea may have updated patches, but I've tested these)
|
Revision tags: release/6.2.0_cvs, release/6.2.0 |
|
#
114b4164 |
| 20-Oct-2006 |
Warner Losh <imp@FreeBSD.org> |
Preliminary MMC stack. This stack supports SD 1.0 cards only, but should be easily adapted to SD 2.0 (aka SDHC), SDIO, MMC and MMCplus cards. At the present time, there's only one bridge driver for
Preliminary MMC stack. This stack supports SD 1.0 cards only, but should be easily adapted to SD 2.0 (aka SDHC), SDIO, MMC and MMCplus cards. At the present time, there's only one bridge driver for the ARM9 based Atmel AT91RM9200.
show more ...
|
#
cbd59a4f |
| 08-Sep-2009 |
Oleksandr Tymoshenko <gonzo@FreeBSD.org> |
- MFC from head@196987
|
#
a56fe095 |
| 20-Aug-2009 |
John Baldwin <jhb@FreeBSD.org> |
Temporarily revert the new-bus locking for 8.0 release. It will be reintroduced after HEAD is reopened for commits by re@.
Approved by: re (kib), attilio
|
#
11e9b8ba |
| 04-Aug-2009 |
Oleksandr Tymoshenko <gonzo@FreeBSD.org> |
- MFC @196061
|
#
444b9186 |
| 02-Aug-2009 |
Attilio Rao <attilio@FreeBSD.org> |
Make the newbus subsystem Giant free by adding the new newbus sxlock. The newbus lock is responsible for protecting newbus internIal structures, device states and devclass flags. It is necessary to h
Make the newbus subsystem Giant free by adding the new newbus sxlock. The newbus lock is responsible for protecting newbus internIal structures, device states and devclass flags. It is necessary to hold it when all such datas are accessed. For the other operations, softc locking should ensure enough protection to avoid races.
Newbus lock is automatically held when virtual operations on the device and bus are invoked when loading the driver or when the suspend/resume take place. For other 'spourious' operations trying to access/modify the newbus topology, newbus lock needs to be automatically acquired and dropped.
For the moment Giant is also acquired in some key point (modules subsystem) in order to avoid problems before the 8.0 release as module handlers could make assumptions about it. This Giant locking should go just after the release happens.
Please keep in mind that the public interface can be expanded in order to provide more support, if there are really necessities at some point and also some bugs could arise as long as the patch needs a bit of further testing.
Bump __FreeBSD_version in order to reflect the newbus lock introduction.
Reviewed by: ed, hps, jhb, imp, mav, scottl No answer by: ariff, thompsa, yongari Tested by: pho, G. Trematerra <giovanni dot trematerra at gmail dot com>, Brandon Gooch <jamesbrandongooch at gmail dot com> Sponsored by: Yahoo! Incorporated Approved by: re (ksmith)
show more ...
|
Revision tags: release/7.2.0_cvs, release/7.2.0 |
|
#
1829d5da |
| 12-Mar-2009 |
Warner Losh <imp@FreeBSD.org> |
Update the projects tree to a newer FreeBSD current.
|
#
125da88a |
| 12-Mar-2009 |
Warner Losh <imp@FreeBSD.org> |
read_ivar takes a uintptr_t * not a u_char *.
|
#
711873d4 |
| 03-Feb-2009 |
Warner Losh <imp@FreeBSD.org> |
o Define some symbols for a few items that are bare constants in the code. o Use NULL in preference to 0 for a few pointers. o default to bus timing normal, like we default to bus_width_1.
|
#
64e4196d |
| 29-Jan-2009 |
Alexander Motin <mav@FreeBSD.org> |
Add one more debug level.
|
#
ed01be88 |
| 28-Jan-2009 |
Alexander Motin <mav@FreeBSD.org> |
Improve mmc driver verbose logging. Make requests logging controllable by hw.mmc.debug sysctl.
|
#
b63865c6 |
| 21-Jan-2009 |
Warner Losh <imp@FreeBSD.org> |
Default to normal bus timing mode on SD cards. In practice, most cards people have today support high speed mode, so the timing field would be initialized to bus_timing_hs, but there are some slow c
Default to normal bus timing mode on SD cards. In practice, most cards people have today support high speed mode, so the timing field would be initialized to bus_timing_hs, but there are some slow cards...
show more ...
|
#
38d1bc23 |
| 21-Jan-2009 |
Warner Losh <imp@FreeBSD.org> |
Fix minor style nit for file consistency.
|
#
3cb54b06 |
| 21-Jan-2009 |
Warner Losh <imp@FreeBSD.org> |
Make the command reporting be under boot verbose. Also, report a few other things under boot verbose. Small style nit to make new code look like old code in this file.
|
#
1e9d4974 |
| 21-Jan-2009 |
Alexander Motin <mav@FreeBSD.org> |
Fix copy/paste mistake in variable name. This could lead to using incorrect bus frequency.
|
Revision tags: release/7.1.0_cvs, release/7.1.0 |
|
#
eb67f31a |
| 06-Dec-2008 |
Alexander Motin <mav@FreeBSD.org> |
Implement suspend/resume for mmc and mmcsd drivers. Now it is possible to suspend/resume with inserted and active card.
To reinitialize card on resume and to detect card change while suspended, impl
Implement suspend/resume for mmc and mmcsd drivers. Now it is possible to suspend/resume with inserted and active card.
To reinitialize card on resume and to detect card change while suspended, implement bus rescan routines. It can also be used by controllers without card presence detection signals or with multiple cards per slot support.
While there, cleanup msleep() usage. We have no any rights to exit without "request done" signal from driver as it could lead to modify after free.
show more ...
|
Revision tags: release/6.4.0_cvs, release/6.4.0 |
|
#
3a4a2557 |
| 29-Oct-2008 |
Alexander Motin <mav@FreeBSD.org> |
Allow card reader bridge driver to report maximum supported transfer size. sdhci supports up to 65535 blocks transfers, at91_mci - one block.
Enable multiblock operations disabled before to follow a
Allow card reader bridge driver to report maximum supported transfer size. sdhci supports up to 65535 blocks transfers, at91_mci - one block.
Enable multiblock operations disabled before to follow at91_mci driver limitations.
Reviewed by: imp@
show more ...
|
#
3906d42d |
| 18-Oct-2008 |
Alexander Motin <mav@FreeBSD.org> |
Implement BIO_DELETE command with MMC and SD erase commands.
Erase operation gives card's logic information about unused areas to help it implement wear-leveling with lower overhead comparing to usu
Implement BIO_DELETE command with MMC and SD erase commands.
Erase operation gives card's logic information about unused areas to help it implement wear-leveling with lower overhead comparing to usual writing. Erase is much faster then write and does not depends on data bus speed. Also as result of hitting in-card write logic optimizations I have measured up to 50% performance boost on writing undersized blocks into preerased areas.
At the same time there are strict limitations on size and allignment of erase operations. We can erase only blocks aligned to the erase sector size and with size multiple of it. Different cards has different erase sector size which usually varies from 64KB to 4MB. SD cards actually allow to erase smaller blocks, but it is much more expensive as it is implemented via read-erase-write sequence and so not sutable for the BIO_DELETE purposes.
Reviewed by: imp@
show more ...
|
#
b231f5d9 |
| 12-Oct-2008 |
Warner Losh <imp@FreeBSD.org> |
style(9): spaces around operators.
|
#
eecec5bd |
| 11-Oct-2008 |
Alexander Motin <mav@FreeBSD.org> |
SELECT_CARD command with zero RCA deselects all cards and so has no reply.
|
#
67d752c3 |
| 11-Oct-2008 |
Alexander Motin <mav@FreeBSD.org> |
Give mmcsd driver a bit more information about card. It allows to reorganize log message in a way a bit more common for disk devices. Also it will allow mmcsd driver to use MMC/SD specific commands w
Give mmcsd driver a bit more information about card. It allows to reorganize log message in a way a bit more common for disk devices. Also it will allow mmcsd driver to use MMC/SD specific commands when needed.
show more ...
|
#
fa5f41d3 |
| 09-Oct-2008 |
Alexander Motin <mav@FreeBSD.org> |
Add high capacity MMC cards support.
|
#
4871891e |
| 09-Oct-2008 |
Warner Losh <imp@FreeBSD.org> |
o Use seprate routines to decode cid and csd for sd and mmc cards. All they have in common right now is a memset. This saves a parameter to these routines, as well as a level of indentation. o
o Use seprate routines to decode cid and csd for sd and mmc cards. All they have in common right now is a memset. This saves a parameter to these routines, as well as a level of indentation. o Make mmc_get_bits a little clearer... It really only works on 128-bit registers right now.
show more ...
|